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STAZIONE DI CONTROLLO GPRS 

di Angelo De Bartolo 

Una stazione di controllo GPRS che monitora costantemente degli ingressi è una 
soluzione più sicura di un combinatore telefonico GSM. Con un budget limitato è possibile 
costruire un sistema completo, dalla stazione periferica fino al server centrale. 


Ci si potrebbe chiedere il motivo di utilizzare una connessione GPRS come sistema di 
segnalazione di uno stato d’allarme quando in commercio esistono numerosi combinatori 
telefonici GSM ad ottimi prezzi. Un motivo risiede nella sicurezza: i combinatori GSM 
effettuano una chiamata vocale nel momento in cui scatta l’ingresso d’allarme pertanto 
basterebbe utilizzare un disturbatore di frequenze (uno jammer GSM, facilmente reperibile 
in rete) per eludere tale controllo. La nostra stazione, invece, si collegherà tramite GPRS 
ad un server (che realizzeremo a partire da zero) ad intervalli regolari: se la stazione 
periferica non si collega entro un tempo massimo di timeout si avviserà della mancata 
connessione. 





Figura 1: Il sistema da realizzare 


Scelta del modulo GPRS 

Il modulo di comunicazione scelto è il famosissimo SIM900 della SIMCom, un modulo 
quad-band GSM-GPRS economico, molto diffuso ed utilizzato in diverse board. Per una 
maggiore semplicità di utilizzo della SIM900 si è preferito acquistare il chip già montato su 
una board completa di tutto l’occorrente (jack microfono, jack cuffie, alimentazione, ecc. 
ecc.) in formato compatibile con le shield Arduino: utilizzeremo lo shield EFCOM PRO 
GPRS/GSM MODULE prodotta da ElecFreaks Studio (figura 1), acquistabile a meno di 
50€ in rete. Il modulo è un Quad-Band 850 / 900/ 1800/ 1900 MHz multislot classe 10/8. 
La descrizione dei pin è rappresentata nella tabella 1. La comunicazione avviene tramite 
due pin utilizzando una trasmissione seriale UART emulata tramite software oppure se 
utilizziamo una eventuale UART hardware presente. L’alimentazione deve essere in grado 
di fornire 2A poiché in alcuni momenti il modulo assorbe molta energia e quindi bisogna 
assolutamente evitare di collegare la scheda ai +5V di Arduino. 
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Figura 2: Lo shield GSM/GPRS della EFCOM 

Primo avvio della scheda. 

Prima di avviare la scheda è necessario assicurarsi di avere un’alimentazione esterna 
capace di erogare almeno 2A (come si legge dal datasheet del modulo SIM900) dato che 
durante le trasmissioni GSM/GPRS ci possono essere dei picchi di assorbimento pari alla 
portata indicata: l’alimentazione esterna la si può applicare tramite il jack presente 
ricordando che è ammessa una tensione compresa tra 4,8VDC-^5VDC. Eventualmente per 
trasmissioni brevi si potrebbe provare ad utilizzare l’alimentazione della board di Arduino 
(assumendosi il rischio, però, di poter danneggiare Arduino): a tale scopo è stato inserito 
un jumper per selezionale l’alimentazione dalla board Arduino o dal jack esterno. Bisogna 
poi inserire la SIM CARD nello slot ed assicurarsi di averla bloccata in posizione LOCK; al 
fine di un corretto funzionamento la SIM non deve avere alcun codice PIN attivo. Ora 
basta solo innestare collegare la shield nell’Arduino e collegare Arduino al PC tramite USB 
e la shield sarà alimentata (a conferma di ciò basta verificare che lo STATUS-LED di 
colore verde si accenda). Per accendere il dispositivo sono presenti un PWR-KEY 
(accensione hardware) ed un pin (D9 per l’accensione via software) dedicati 
all’accensione e spegnimento del dispositivo: una volta acceso (via hardware o software) il 
led NET-LIGHT (di colore rosso) del dispositivo inizierà a lampeggiare con frequenza di 1 
ogni 800ms circa fino all’aggancio della rete: una volta che la SIM si sarà registrata sulla 
rete del nostro operatore telefonico i lampeggi saranno più lenti (alla frequenza di 1 ogni 3 
secondi circa). 

Creazione del server web 

Un server web per “uso domestico” può essere facilmente configurabile installando il 
software XAMPP sia su piattaforme Windows che Linux o anche Mac. Inutile dilungarsi 
sull’installazione ed altri approfondimenti dato che in rete si trovano guide, tutorial e 
documentazione varia anche in italiano. Ancor meglio sarebbe virtualizzare il server in 
modo tale che se eventualmente venisse infettato o attaccato dall’esterno il tutto 
coinvolgerebbe solo il sistema virtuale. Per questa prova, invece, ho preferito utilizzare 
come server non un PC personale configurato ad-hoc ma un server esterno e la scelta è 
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ricaduta in uno dei più famosi web hosting: altervista. 

La registrazione di uno spazio gratuito è semplicissima, basta inserire il nome del sito che 
si vuole creare (in questo caso si è scelto http://sicur.altervista.it) ed inserire i propri dati 
personali. Per la tipologia di utilizzo adatta ai nostri scopi non è necessario creare alcun 
contenuto del sito e pertanto si utilizzerà esclusivamente il pannello di controllo per 
caricare i file php necessari al funzionamento del server. 

La funzione che il nostro server dovrà svolgere è la “custodia” dei valori degli ingressi della 
stazione GPRS selezionata: i dati vengono salvati su file TXT residenti nel server il cui 
nome del file inizia con il numero di telefono della stazione seguito da un simbolo di 
underline e le diciture “IN” oppure “PWD” a seconda se dobbiamo lavorare con gli ingressi 
(IN) o con la password (PWD). Supponendo come numero di telefono della stazione 
3331234567 si adopereranno due files: 

-un file “3331234567_IN.txt” che contiene al suo interno il valore degli ingressi; 

-un file “3331234567_PWD.txt” che contiene al suo interno la password; 







Figura 3:1 file di dati (in blu) e delle funzioni (in grigio) contenuti nel Server 


Il codice è abbastanza semplice ed intuitivo anche per chi (come me) non è un 
programmatore esperto del PHP: i valori delle variabili vengono passate direttamente nella 
uri del sito (tipico passaggio dei parametri con metodo GET) mentre per essere recuperate 
viene utilizzato all’interno dello script PHP il metodo GET; una volta recuperate le variabili 
si verifica che la password passata nella uri sia coincidente con quella indicata nel file 
“numtel_PWD.txt” e solo in questo caso si procede a leggere o scrivere i dati nei files. 


Leggere e scrivere i valori degli ingressi 

La board Arduino aggiornerà il file “numtel_IN.txt” ogni qualvolta che almeno uno degli 
ingressi cambia stato; per fare ciò Arduino si connetterà ad internet richiamando l’URL 
dello script scrivi.php passando come parametri il numero di telefono, i valori dei singoli 
ingressi e la password. Lo script apre il file in modalità “w+” (modalità scrittura partendo 
dall’inizio del file) ovvero se il file non esiste viene creato mentre se già esiste viene 
sovrascritto e la scrittura parte dall’inizio del file, in coda al fine viene invece inserita la 
data e l’ora corrente formattate secondo le proprie preferenze. Un contenuto tipico del file 
“numtel_IN.txt” può essere il seguente: 
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$ 1 % 1 % 1 %0%0015%01 /09/2014 12:00:00 

indicante che gli ingressi 1,2 e 3 sono al livello logico High (valore 1) mentre l’ingresso 4 è 
al livello logico LOW (valore 0), l’ingresso analogico ha valore 0015 (su una scala che va 
da 0 a 1023) e che l’ultimo salvataggio dei dati è avvenuto alle ore 12 del 1 settembre. 



URL da usare: http://sicur.atten/ista.org/scrivi.php?numtel=333123457&ingrl=l &ingr2=l &ingr3=0&ingr4=0&analog=0015&pwd=123456 

Iniziale 

Valore INGR 1 

Separatore 

Valore INGR 2 

Separatore 

Valore INGR 3 

Separatore 

Valore INGR 4 

Separatore 

Valore Analog. 
(0 + 1023) 

Separatore 

Data formato 

GG/MM/AAAA 

Separatore 

Ora formato 

HH:MM:SS 

S 

1 

% 

1 

% 

1 

% 

0 

% 

0015 

% 

01/09/2014 


12:00:00 



URL da usare: http://sicur.altervista.org/leggi.php?numtel=3331234567&pwd=123456 

Iniziale 

Valore INGR 1 

Separatore 

Valore INGR 2 

Separatore 

Valore INGR 3 

Separatore 

Valore INGR 4 

Separatore 

Valore Analog. 
(0 + 1023) 

Separatore 

Data formato 

GG/MM/AAAA 

Spazio 

Separatore 

Ora formato 

HH:MM:SS 

$ 

1 

% 

1 

% 

1 

% 

0 

% 

0015 

% 

01/09/2014 


12:00:00 


Figura 4: Contenuto del file 3331234567_IN.txt e le URL perla lettura e scrittura 

Il valore analogico è compreso nel tipico intervallo di un campionatore a 10 bit i cui valori 
analogici sono compresi tra 0 e 5V con passo 4,9mV, pertanto se il nostro segnale 
analogico ha escursioni maggiori dobbiamo elaborare un circuito di condizionamento del 
segnale che lo faccia rientrare nel range di funzionamento di Arduino. Un esempio banale 
può essere dato da un valore con escursione del segnale da 0 a 12V, pertanto risolvendo 
con un semplice partitore di tensione abbiamo che il limite dei 12V deve corrispondere a 
5V pertanto devono essere rispettate la seguenti relazioni: 

12V ——— = 5V 12V—^^ = 12V-5V 

Ri + R 2 q R\+ R 2 (jg cu j Ri = 14 kd q R 2 — 10AQ 

Al fine di garantire un corretto funzionamento è indispensabile che le masse dei segnali 
12V e 5V di Arduino siano allo stesso potenziale, ovvero cortocircuitati. 

Tornando alla scrittura del file sul server è utile precisare che questa funzione (scrivi.php) 
verrà richiamata esclusivamente da Arduino per salvare lo stato attuale degli ingressi e 
verrà richiamata sia nel caso in cui varia lo stato di un ingresso e sia allo scadere di un 
timer impostato in maniera tale da prevenire eventuali attacchi da parte di dispositivi 
jammer (se il file non viene aggiornato continuamente si può supporre che ci sia un 
attacco al sistema). La lettura dello stato degli ingressi avviene, invece, ad opera del 
software di gestione richiamando l’URL dello script leggi.php del server e passando il 
numero di telefono e la password. Lo script opera aprendo il file in modalità “r” (modalità 
solo lettura partendo dall’inizio del file) e costruisce una stringa con i caratteri che legge 
aN’interno del file “numtel_IN.txt”: tale stringa verrà restituita tramite un comando echo a 
fine script. 


Librerie o comandi AT. 

Esistono in rete molteplici librerie per semplificare la gestione del modulo SIM900 ed il 
risparmio di energie è notevole: anziché comunicare attraverso comandi in standard AT si 
usano delle funzioni più ad alto livello che risultano molto più comprensibili. Tra le varie 
librerie merita di essere menzionata la libreria Open Source di GSMLIB.ORG sia perché è 
Open Source e sia perché è modulare, nel senso che si possono importare solo i moduli di 
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cui necessitiamo al fine di risparmiare risorse in termini di RAM e sia per la semplicità e 
potenzialità: la libreria si può scaricare dal sito https://code.google.com/p/gsm-shield- 
arduino/ o dal sito ufficiale http://www.gsmlib.org/ . La scelta adottata da me è stata quella 
di utilizzare i comandi AT per avere un maggiore controllo: è possibile trovare in rete molta 
documentazione sui comandi AT, ma consiglio di leggersi la guida ai comandi AT della 
SimCom (la si trova all’indirizzo http://wm.sim. com/downloaden.aspx?id=2986). 


Il firmware di Arduino 

Lo sketch contenuto nel file sicurduino.ino si apre inizializzando i PIN RX e TX che 
comunicheranno via seriale emulata con lo shield creando un’istanza della classe 
SoftwareSerial e configurando i PIN che saranno gli INPUT digitali e analogici. Vengono 
poi create le variabili che memorizzano lo stato precedente degli input che serviranno per 
stabilire se un ingresso ha variato il suo stato o meno. Viene infine creata un’ultima 
variabile globale: uri che è una stringa che contiene l’uri da richiamare nella funzione 
comunica(). Nella sezione setup dello sketch vengono impostati i PIN digitali in modalità 
INPUT_PULLUP in cui vengono abilitati dei resistori interni di pull-up che mantengono in 
HIGH il valore delle porte fino a che non interviene un cortocircuito verso massa 
determinato, magari, da un sensore che in caso di allarme richiuda il contatto verso GND. 
Lo sketch prosegue eseguendo in loop due routine: verificalngressi() e verificaTimer(). La 
funzione verificalngressi() confronta il valore attuale degli ingressi con il valore salvato 
nelle variabili di stato: se il valore salvato differisce da quello attuale si procede a 
modificare la stringa dell’uri (la variabile uri) da richiamare al momento della trasmissione 
dati alla centrale. Si costruiscono due stringhe: una stringa viene ottenuta tramite la 
funzione substring e contiene il vecchio valore dell’ingresso; l’altra stringa viene costruita 
con il nuovo valore dell’ingresso. Si procede mediante la funzione replace della classe 
String ad attuare la sostituzione delle due stringhe all’interno della variabile uri. 


. 76 77 

78 79 80 

81 

82 83 

84 

85 86 87 

88 89 90 

91 ... 

5 6 7 & i 

n g r 

1 

= 1 

& 

i n g 

r 2 = 

1 & 


Figura 5: Caratteri estratti dalla funzione substring 

Per ciò che riguarda il valore analogico viene trasformato in una stringa di dimensione 
fissa di 4 caratteri i cui valori nulli sono sostituiti da “0” (ad esempio un valore “15” viene 
trasformato in “0015”). Infine viene richiamata la routine comunica() che “naviga” l’uri in cui 
sono contenuti i dati da passare al server tramite metodo GET. La routine comunica() è 
composta unicamente da stringhe di comandi che vengono passati al SIM900: si tratta di 
una sequenza di comandi AT che configurano ed abilitano il servizio GPRS e che 
effettuano una richiesta http all’uri desiderato. 

La seconda routine richiamata nel loop è verificaTimer() che sfrutta la funzione millis() la 
quale restituisce il numero di millisecondi trascorsi dall’accensione di Arduino: viene 
verificata la differenza tra i millisecondi trascorsi al momento della chiamata della funzione 
millis() e l’ultimo valore salvato nella variabile prevMillis; se la differenza tra i due valori 
supera il valore della variabile intervallo allora significa che è necessario sincronizzarsi con 
la centrale al fine di evitare un messaggio di timeout nel software di gestione installato sul 
PC. Il timer millis() va in overflow ogni 49,7 giorni circa ricominciando il conteggio da 0 e 
tale situazione è trasparente al codice. 
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Il software di gestione 

Per semplificare e velocizzare lo sviluppo del software è stato utilizzato come linguaggio di 
programmazione il Visual Basic .NET in ambiente di sviluppo Microsoft Visual Studio 2008 
Express Edition (versione gratuita): tale scelta è, ovviamente, personale e non vincolante. 
Senza entrare nello specifico, dato che il codice è ampiamente commentato, si 
illustreranno le principali funzioni e routine del software. 


/ 3 

/ a 

controllaEsistenzaf) -> Boote a n 


mostraStazione(numtel) 

Richiama la funzione mostraStazionefnumtei) e calcola 


Legge il contenuto del file numtel_IN.TXT presente sul 

la differenza tra la data e l'ora dell'ultima sync e la 


server tramite la funzione leggiPHP(url) che restituisce 

data e l'ora attuale: restituisce FALSE se la differenza è 


una stringa come risultato della lettura. Aggiorna i dati 

maggiore del timeout impostato, altrimenti TRUE 

V 


sul pannello di lettura. 

_ V 


£ 


Attraverso i namespace IO e NET crea una richiesta di 
una risorsa dal server "navigando" l'uri della funzione 
leggi php del server con i parametri restituisce il 
contenuto del file numtel_IN.TXT come stringa in OUT 


r 



r 




/ 



Forml_Load() 



aggiornaLedO 

Nel file di risorsa "setup.ini" estrae il numero di 





telefono, i dati identificativi della stazione, la password 



Aggiorna i led tramite delle Immagini presenti nelle 


ed il timeout. Aggiorna sul pannello i dati ed imposta 



risorse dell'applicazione 


l'intervallo del Tìmer3 e richiama contmlloEsistenzoO. 








r 




Funziona da orologio con cadenza 1 secondo. 




Controlla ogni 60 secondi se le uscite sono in stato 
d'allarme ed eventualmente mostra un messaggio. 


Richiama la funzione mostraStazionefnumtei) circa 30 
secondi prima dello scadere del timeout impostato. 


Richiama la funzione mostroStazione(numtel) 
aggiornando i dati sul pannello 


Button2_Click() 


Imposta il Rag "tacito" su TRUE o FALSE inibendo la 
segnalazione degli allarmi di Timer2. 




Mostra le info sul programma e sul sistema 


Button4_Click() 


Esce dal programma. 


Figura 6: Procedure e Funzioni del Software realizzato in VB.NET 2008 

All’avvio del programma verrà eseguito il codice aN’interno della Sub Form1_Load e si 
inizia a leggere aH’interno del file setup.ini che è stato inserito come risorsa del 
programma. Il file setup.ini contiene il numero di telefono, il titolo, l’indirizzo e la password 
della stazione da monitorare, tutte separate dal carattere “ A ”. Viene richiamata la Sub 
mostraStazione che scarica dal server i dati degli ingressi e dell’ultima sincronizzazione 
tramite la chiamata dello script leggi.php presente sul server. Si procede ad impostare il 
Timer3 affinché controlli 30 secondi prima del tempo di timeout se la stazione sta 
correttamente comunicando con la centrale; a tal fine viene chiamata la Sub 
controllaEsistenza che, in caso di mancata comunicazione entro il termine massimo di 
timeout, avverte l’utente aprendo una MessageBox di avviso. La routine mostraStazione è 
realizzata tramite una chiamata alla Sub leggiPHP che crea una richiesta di pagina web 
attraverso le funzioni del namespace System.Net e che restituisce una stringa contenente 
la risposta dal server. La risposta è, quindi, la stringa contenuta nel file numtel_IN.txt che 
sarà del tipo 

$ 1 % 1 % 1 %0%0015%01 /09/2014 12:00:00 
con il significato visto in precedenza. 

La Sub controllaEsistenza si realizza recuperando dal server la data e l’ora dell’ultima 
sincronizzazione e poi la confronta con la data e l’ora attuale: se la differenza è maggiore 
del tempo di timeout restituisce il valore False il quale indica che la stazione non sta 
trasmettendo alla centrale. 
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La diretta conseguenza della scelta di non usare un database engine porta ad utilizzare le 
funzioni della classe String (come ad esempio Substring e Concat) al posto di richiamare i 
campi di una tabella che risulterebbe sicuramente più leggibile a livello di codice ma 
appesantirebbe il progetto nel suo complesso (sarebbe necessario installare il pesante 
MySqlServer o altro database engine). 



Figura 1: Una schermata del software 


Conclusioni 

Volutamente il sistema periferica-centrale è stato semplificato ed alcuni aspetti non sono 
stati approfonditi mentre altri sono stati completamente trascurati. Espandere il sistema è 
possibile, anzi è consigliabile, soprattutto se l’utilizzo non è del tipo didattico ma semi¬ 
professionale. Ad esempio si potrebbe rendere personalizzabile la stazione da monitorare 
sul software del PC, cambiare la password sul sistema Arduino-SIM900 tramite SMS di 
configurazione (memorizzando i dati nella EEPROM interna di Arduino ad esempio), 
controllare la risposta dei comandi AT del SIM900 per verificare se si può procedere con il 
comando successivo, aumentare la sicurezza del server ed altre migliorie. 


Pin 

Descrizione 

GND 

Massa di alimentazione 

+5V 

Positivo di alimentazione (min. 2A) 

DO 

RX in comunicazione UART Hardware 

DI 

TX in comunicazione UART Hardware 

D7 

RX in comunicazione UART Software 

D8 

TX in comunicazione UART Software 

D9 

Comando di Power Software 

Tabellal: Ini 

l erfaccia dello SHIELD EFCOM PRO GPRS/GSM 
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Introduzione ai sistemi 


ASIC, FPGA e CPLD 

Di Massimiliano Miocchi 

La migrazione di un progetto basato su FPGA o CPLD in un progetto basato su ASIC può 
sembrare a prima impegnativo ed oneroso per un team di progettazione, ma un’attenta 
pianificazione possono facilitare notevolmente questo processo 


Per trasformare un progetto digitale realizzato tramite FPGA in un equivalente progetto 
adatto alla produzione di massa vi sono varie soluzioni: Soluzioni a basso costo come i 
circuiti ASIC (Application-Specific Integrated Circuit) strutturati, i circuiti integrati basati su 
celle standard e gate array di gate offrono prestazioni più elevate, un minore consumo 
energetico, una migliore integrazione e una maggiore immunità ai disturbi elettromagnetici. 
La migrazione di un progetto basato su FPGA in un progetto basato su ASIC può 
sembrare a prima vista impegnativo per un team di progettazione, ma un’attenta 
pianificazione possono facilitare notevolmente questo processo. 

Progettare un nuovo prodotto sfruttando la tecnologia FPGA permette di introdurre 
rapidamente eventuali modifiche di progetto direttamente a livello hardware. Quando il 
codice del progetto è stabile e il dispositivo è pronto per la produzione, la migrazione da 
un FPGA a un ASIC può comportare una riduzione fino al 50% il costo unitario di 
produzione. 

I sistemi più complessi potrebbero richiedere diversi circuiti FPGA per realizzare un 
prototipo di un intero progetto SoC(System-on-a-Chip). Gli ASIC offrono una maggiore 
densità di gate e prestazioni di base maggiori rispetto agli FPGA. 

Ciò consente di combinare più FPGA in un unico SoC ASIC, risparmiando spazio prezioso 
sulla scheda di conseguenza abbattendo i costi. Se l’architettura non permette una piena 
integrazione, è possibile realizzare una sostituzione funzionale diretta e veloce, 
producendo un ASIC multifunzionale in grado di emulare i diversi circuiti FPGA. Questa 
soluzione ottimizza i risparmi riducendo i costi per la trasformazione in tecnologia ASIC. Ci 
sono diversi aspetti da considerare nel flusso produttivo di questa tecnologia, un aspetto 
importante è sicuramente la produzione cn flusso parallelo: 


Flusso produttivo parallelo 

I flussi di progettazione parallela permettono di abbreviare i tempi di sviluppo dell’ASIC. La 
prototipazione FPGA permette 

ai team tecnici di verificare la funzionalità prima della realizzazione fisica del circuito ASIC 
e dà inoltre la possibilità di collaudare in maniera tempestiva l’hardware e il software 
utilizzati. In questo flusso di progettazione, il codice RTL (Register Transfer Level) viene 
sviluppato e adattato all’FPGA e contestualmente dato al fornitore di ASIC per essere 
analizzato e rivisto. Ciò permette al fornitore di ASIC di fornire raccomandazioni ed 
effettuare modifiche al codice al fine di aumentarne la robustezza. Gli script di 
temporizzazione e le architetture di clock vengono sviluppate sia per l’FPGA che per 
l’ASIC. Il package dell’ASIC viene scelto valutando anche le problematiche di integrità del 
segnale e della dissipazione di potenza. Il circuito stampato può essere progettato in 
questa fase tenendo conto sia della presenza degli FPGA, che assorbono più potenza, sia 
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della successiva migrazione più circuiti ASIC fisicamente più piccoli e più efficienti sotto 
l’aspetto energetico. 

Abbiamo fin qui accennato ad una delle più avanzate tecnologie in uso, se pur complesse 
le ASIC. Non necessariamente si deve ricorrere a tale tecnologia , almeno non in questo 
contesto dove analizzeremo in modo semplice e chiaro la struttura di una FPGA e le 
differenze funzionali con le CPLD. Il lettore tenga bene in mente che oggi quando si parla 
di tecnologia FPGA implicitamente ci si proietta in un sistema di progettazione 
completamente diverso, non più statico come può essere l'uso degli IC ma dinamico come 
i DSPo digitai signal processor. 

Tutti noi abbiamo trovato difficoltà non sempre superabili nel progettare sistemi sequenziali 
o combinatori dove l'uso di eccezioni o processi di confronto assumono complessità 
notevoli; bene, in queste circostanze è consigliabile l'uso di FPGA o microcontrollori 
rendendo la vita facile al progettista per cosi dire... 

In definitiva gli FPGA permettono di commercializzare rapidamente un prodotto e 
costituiscono un efficiente strumento di prototipazione, ma l’elevato costo degli FPGA di 
fascia medio-alta può essere proibitivo per passare a una produzione di massa. Con una 
corretta pianificazione durante la fase di sviluppo, la migrazione da FPGA ad ASIC può 
essere perfezionata rapidamente senza ulteriori sforzi. Vediamo ora come si è arrivati alle 
attuali tecnologie DSP.CPLD e FPGA. 

Prima dell'avvento sui mercati mondiali delle tecnologie a microprocessore la tecnologia 
del tempo si presentava molto complessa in virtù del massivo utilizzo delle logiche 
combinatorie e sequenziali demandate ai single chip. Questo oltre a portare un dispendio 
di risorse portava con se anche un grande spreco nella progettazione in se, sia in termini 
di costi che di componentistica. 


L'elettronica digitale PRIMA dei microcontrollori 

Le tecnologie prima degli anni 90 erano per l'appunto le famiglie logiche ,con le quali si 
realizzava tutto, dai sistemi di controllo a quelli di trasmissione e recezione e non senza 
complicazioni. 



Prima dei Microcontrollori le macchine di calcolo erano come in figura: 



Anche le centraline auto che oggi sono super automatiche con protocolli di trasmissione 
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come il CanBus, all'epoca erano cosi: 



Centralina auto: ECU 


per non parlare delle schede RAM, circuitene molto complesse: 



Tutto questo ha fatto da generatore per avviare un processo di evoluzione tecnologica 
dettato dalle pressanti e difficili esigenze di mercato. 


L’ERA DELLE LOGICHE TTL 

La tecnologia delle logiche discrete TTL ottenne il battesimo ufficiale quando, agli inizi 
degli anni ‘60, la Texas Instruments introdusse la già accennata famiglia 74 di circuiti 
integrati di tipo standard logie per supportare i programmi di esplorazione spaziale, in 
particolare lunare, della NASA. 

La famiglia 74 (di cui in figura 1.2 è rappresentato un esemplare) comprendeva le porte 
logiche elementari, come ad esempio il quadruplo NAND 7400 (figura 1.3), oltre alle varie 
tipologie di flip-flop (tra cui il celebre 7474), i contatori (come il 7493), i sommatori binari e 
altre semplici funzioni. I primi integrati erano fabbricati nei package dual-in-line a 14 e 16 
pin. 

I successivi progressi nel packaging e l’introduzione di dispositivi a livelli via via crescenti 
di integrazione consentirono ai progettisti di minimizzare drasticamente gli ingombri sui 
circuiti stampati e di ridurre il numero di componenti complessivo (il cosiddetto chip count), 
fornendo nel contempo un comodo sistema "ad incastro" del tipo a blocchetti Lego. 

Con il trascorrere degli anni nuove famiglie venivano introdotte continuamente, atte a 
soddisfare le necessità di aumento delle prestazioni in frequenza, minori consumi e 
riduzione dei costi. Il risultato fu la proliferazione di oltre trenta differenti famiglie 74, 
ciascuna con specifiche caratteristiche. Attraverso gli anni 70 le varianti delle famiglie TTL 
si diffusero rapidamente e, di pari passo, neaumentò la complessità. Nei primi anni ’80 era 
presente sul mercato un’ estrema varietà di tipologie : TTL, S, LS, AS, F, ALS, CD4000, 
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HC, HCT, BCT, AC, ACT, FCT, ABT, LVT, AHC, AHCT, ecc.., tali da costringere i progettisti 
a destreggiarsi a fatica tra le caratteristiche di ognuna e le reciproche compatibilità 
elettriche per poter al meglio realizzare le proprie applicazioni. 


NASCITA E AVVENTO DELLE CPLD 

Mentre la gamma dei dispositivi 74 si espandeva, cominciava ad apparire una nuova 
tendenza rivoluzionaria nella forma dei componenti logici programmabili, detti PLD 
(Programmable Logic Devices). Oltre a consentire all’ utilizzatore la caratteristica della 
programmabilità, la prima generazione di questi chip poteva rimpiazzare fino a una diecina 
di integrati logici discreti. In seguito, con l’avanzare del processo di integrazione, le PLD 
furono in grado di sostituire sempre più numerose funzioni logiche standard. Oggi, le più 
avanzate CPLD (Complex PLD) contengono decine di migliaia di gates e la loro capacità 
equivalente corrisponde a quella di centinaia di dispositivi della serie 74. 

Ecco come ci si spinse oltre la logica fissa. 


Esigenze tecniche e di mercato 

Le richieste di flessibilità e integrazione hanno generato la necessità di 
dover raggruppare: 

• Parallelismo delle operazioni 

• Numero delle variabili di controllo 

• Velocità di risposta 

• Modularità del sistema 

• Affidabilità del controllo 

• Flessibilità dei componenti 

• Reti logiche 

• Logiche programmabili 

• Controlli digitali e analogici 

Se ne evince: 

Riduzione dimensioni, riduzione costi, flessibilità, programmabilità 

A questo punto è lecito osservare come il microcontrollore cominci a divenire 
indispensabile la dove le variabili in gioco erano molte, quindi complesse da controllare. 
Da qui si capisce come un microcontrollore sia efficace nello svolgere determinate funzioni 
come: 


• Comunica con l'esterno solo mediante porte di input/output 

• Esegue esclusivamente operazioni logiche, aritmetiche e di controllo 

• Elabora sia dati prodotti internamente che provenienti da dispositivi esterni 

• Totalmente dipendente da elementi periferici 

• Non presenta elementi per la memorizzazione permanente dei dati 


Il microcontrollore racchiude tutte le caratteristiche del microprocessore aggiungendo le 
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possibilità di: 

• Comunicazione diretta con dispositivi esterni integrando periferiche interne 

• Memorizzazione di dati o programmi 

• Effettuare operazioni di controllo, ricezione ed elaborazione segnali 

• In generale non necessitano ulteriori aggiunte di memoria RAM oltre a quella 
integrata 

• Eseguono esclusivamente le operazioni legate al firmware con il quale sono stati 
programmati 


Microcontrollore e Microprocessore 


Microcontrollore: 


Microprocessore: 


• Microprocessore 

• Linee I/O 

• Memoria Flash 

• Convertirore A/D 

• Timer 

• USART 

• SPI 

• PWM 


• Unità di calcolo 

• Unità di controllo 

• Memoria istruzioni e calcolo 



Il microcontrollore è un'estensione del microprocessore, le sue caratteristiche lo 
avvicinano molto ad un computer completo. In definitiva il microcontrollore è un “sistema” 
a microprocessore realizzato con una logica di ottimizzazione del rapporto 
prezzo/prestazioni. A differenza del microprocessore ha un esteso campo di impiego che 
può spaziare dai più semplici oggetti di utilizzo quotidiano a complesse architetture in 
ambito medicale e industriale. Ha una capacità di calcolo relativamente limitata ed esegue 
esclusivamente una serie di operazioni contenuta aN'interno del programma o firmware 
caricato nella memoria. 

Le prime logiche programmabili nate negli anni ‘80 offrivano la possibilità di manipolare 
migliaia di gate di logica programmabile nelle tecnologie allora presenti. Questi dispositivi 
si indirizzavano ai progettisti che ambivano ad integrazioni logiche e volevano evitare i 
rischi connessi alle rigidità dei gate array ,ove potevano farne a meno. Inoltre,il tempo di 
ingresso nel mercato, dalla fase di stesura delle specifiche, era divenuto un requisito 
critico per la competitività sul mercato stesso. Sfruttando la riduzione del ciclo progettuale 
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che ne scaturiva con questo metodo di lavoro, i vari progettisti riuscivano ad introdurre 
nuovi prodotti sempre più rapidamente. Inizialmente questi dispositivi venivano chiamati 
High Density PLD ed erano considerate un’estensione logica delle logiche programmabili 
allora presenti (PAL e GAL). Essi venivano utilizzati in modo simile, cioè integrazione di 
logica sparsa (glue logie) precedentemente implementata usando circuiti integrati TTL e 
sostituzione di gate array di bassa densità.Pian piano con l'avanzare del tempo e con 
l’introduzione di nuove famiglie di componenti, nel tentativo di distinguere le differenti 
architetture di PLD, le varie case produttrici proposero il termine Field Programmable Gate 
Array (FPGA). Attualmente il processo tecnologico a 28nm ha permesso alle grosse case 
produttrici come ad esempio la Xilinx, di produrre FPGA ad elevatissimo numero di celle 
logiche programmabili: ad esempio l'ultimo arrivato in casa Xilinx è il Virtex 7 il quale 
presenta ben 2 milioni di celle logiche, 8 porte PCIe GEN3 e la possibilità di disporre di 
1200 pin di I/O..e molto altro! 

Struttura interna di una FPGA 



PIN100 

Fig. 1.1 - Configurazione dell'FPGA (IN) 


PIN120 

(OUT) 


Ogni FPGA viene realizzata attraverso una matrice di blocchi logichi configurabili o 
Configurable Logic Blocks (CLB), i quali vengono connessi attraverso delle opportune 
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Interconnessioni (piste metalliche) sia tra di loro che con pin di I/O per comunicare con 
segnali esterni all'FPGA. Analizziamo prima i CLB: ogni elemento logico della matrice 
viene interconnesso a quelli circostanti tramite due canali: uno verticale e uno orizzontale. 
Nei punti in cui il canale orizzontale incrocia quello verticale, vengono posizionati degli 
elementi contenenti la logica programmabile necessaria a gestire le connessioni: gli switch 
modules. Quindi grazie a tali elementi, è possibile realizzare un certo numero (finito) di 
funzioni logiche e il vantaggio sta tutto nel poter riprogrammare opportunamente le 
connessioni tra le varie CLB in modo tale da cambiare la funzione logica. Il limite 
ovviamente è dovuto al fatto che i CLB e i pin di I/O sono in numero finito quindi la 
funzione o le funzioni avranno un numero di operazioni finito (ad esempio al più non 
possiamo realizzare più di 10 funzioni che fanno quattro somme tipo Y=A+B+C+D ecc..). 

Per non appesantire troppo l'articolo descriviamo brevemente la struttura di un CLB: Ogni 
CLB è costituito a sua volta da un altro elemento logico di base chiamato BLE. Il BLE è 
composto a sua volta da elementi logici combinatori e sequenziali, in pratica una Look Up 
Table(a 4 ingressi nell'esempio in figura) e un flip flop D. Il motivo per il quale si utilizza 
questa tecnica di raggruppare le LUT in BLE e poi in CLB è dovuto essenzialmente al fatto 
che facendo in questo modo si riducono i tempi di ritardo medi dovuti alla propagazione 
del segnale nelle varie interconnessioni. Le interconnessioni: Come già detto in 
precedenza i vari elementi logici sono connessi tra loro tramite due canali: ciascuno di 
questi due canali viene realizzato tramite delle piste metalliche le quali vengono anche 
dette "wire segment": ogni interconnessione si misura a seconda di quante CLB essa 
attraversa. 




Figura 1.3a Blocco logico (CLB) 


Figura 1.3b Elemento logico di base (BLE) 


Il lettore tenga presente che qualsiasi sistema digitale può realizzarsi utilizzando i quattro 
elementi fondamentali: le porte NOT,AND e OR e i flip-flop. Disponendo di un circuito 
integrato in cui sono realizzati già dal costruttore tali elementi fondamentali, avendo invece 
la libertà di connetterli in base alle particolari specifiche volute, consente la realizzazione 
un qualunque sistema digitale, anche complesso, e fabbricato utilizzando un unico circuito 
integrato il cui test di funzionalità è stato già eseguito. Nasce proprio così l'idea di 
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dispositivi programmabili dall'utente che, grazie all'enorme progresso in termini sia di costo 
che di livello di integrazione, ha portato a interessanti progressi dei PLD ( Programmable 
Logic Devices ). Spesso, più propriamente, tali dispositivi vengono denominati come 
programmabili sul campo FPD, (Field Programmable Device) nel senso che è l'utente 
finale a poter programmare la funzione specifica; I PLD nascono per applicazioni di 
elettronica digitale anche se recentemente molti sono i prodotti che cercano di portare la 
stessa filosofia di progettazione e architettura in ambiente analogico. 

Oltre alla tecnologia FPGA abbiamo le CPLD o EPLD, nascono prima sempre sull'ona 
della medesima filosofia di progetto. 

Sono dispositivi che presentano una complessità maggiore sono generalmente 
riprogrammabili . Questi consistono tipicamente in più Gate Array Logic integrati su un solo 
chip. Nella struttura si possono distinguere i blocchi in cui può essere configurata una 
funzione logica (CFB, Configurable Function Block o GLB, Generic Logic Block) e una 
matrice di interconnessione programmabile centralizzata (GRP, global routing Poo). La 
similitudine con le FPGA è forte, spesso e volentieri conviene utilizzare le CPLD in 
applicazioni di reti complesse ove non sarebbe giustificata la FPGA. La struttura di una 
CPLD è rappresentata in figura: 
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CONVENIENZA DELLE LOGICHE PROGRAMMABILI 

I componenti logici discreti, a lungo considerati i cavalli di battaglia dell’industria dei 
semiconduttori, sono stati per parecchi anni avvantaggiati dai bassi costi, rispetto alle 
prime logiche programmabili comparse agli inizi sul mercato. 

Tuttavia, oggi le cose sono cambiate radicalmente; i progressi compiuti negli anni più 
recenti nel campo delle tecnologie di costruzione delle CPLD hanno abbassato i costi di 
produzione di questi dispositivi a un livello tale da farli divenire alternative molto appetibili 
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rispetto alle logiche fisse discrete. 

Ma, al di là delle semplici ragioni di costo, vi sono altri fattori particolarmente rilevanti che 
rappresentano notevoli vantaggi a favore delle CPLD : la flessibilità costituita dalla 
riprogrammabilità, la rapidità nell’ apportare le modifiche, la riduzione dell’area occupata 
sullo stampato, la superiore affidabilità rispetto alle logiche discrete, il ridotto time-to- 
market, solo per citare i più importanti. 

Osservazioni 

Il lettore tenga presente che lo studio e l'applicazione di tecnologie FPGA o CPLD è 
strettamente legata alla conoscenza dei microcontrollori, inoltre sono chip molto delicati 
facili da danneggiare se non si osservano regole ben precise nell'utilizzarle. Per il resto 
sono affascinanti consentono di realizzare combinazioni di sistemi complessi con estrema 
efficacia e velocità, si velocità parliamo di strutture capaci di viaggiare anche a centinaia di 
Mhz. Nella prossima puntata realizzeremo una demo board con a bordo una CPLD della 
Xilinx necessaria al prosequio del mini corso. Per chi fosse curioso può documentarsi sul 
linguaggio vhdl, standard come il verilog per la programmazione hardware di questi 
gioiellini. 
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Interfacciamento Sensore di Pressione 
MPX4115AP con il PIC18F45K222 


di Alberto Trasimeni 

Esiste una ampia scelta di sensori di pressione assoluta con range di misurazione che va 
dai 15Kpa ai 115Kpa,tali sensori sono ideali per la realizzazione di barometri ed altimetri. 
In questo articolo prenderò in considerazione il sensore MPX4115AP della Freescale che 
risulta compensato in temperatura e calibrato. 

Caratteristiche generali del sensore e del PIC 

Il sensore MPX4115AP è un sensore di pressione assoluta di tipo analogico, quindi per 
leggere la misura di pressione fornita, è necessario fare uso di un convertitore 
analogico/digitale. Per interfacciarlo sfrutterò il PICI 8F45K22,dotato di più convertitori 
analogico/digitale e tutti a 10 bit di conversione. Inoltre userò l’oscillatore interno del 
microcontrollore, alla frequenza di 8Mhz.Come sistema di sviluppo,per il progetto, mi 
servirò della EasyPIC7 della MikroElektronica e come ambiente di sviluppo software, 
adopererò il MikroC, nella sua ultima versione la 6.4.0. 

Le caratteristiche principali del sensore sono: 

• Massimo errore nella misura è del ±1,5% con temperatura compresa tra 0 e 85 
gradi Celsius. 

• Ideale per applicazioni basate su microprocessore/microcontrollore. 

• Applicazioni più ricorrenti realizzazione di altimetri e barometri 

L’unità di misura della pressione fornita è Kpascal ma può essere facilmente convertita in 
millibar e Torricelli. 


Il sensore si presenta fisicamente come in figura sottostante. 



MPX4115AP 
CASE 867B-04 


Figura 1: Case del sensore MPX4115 


La struttura funzionale interna è costituita da un elemento sensibile alla pressione seguito 
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da un primo stadio, il cui scopo è quello di compensare la misura di pressione con la 
temperatura, mentre il secondo ha la funzione di bilanciare l’uscita verso massa, come 
mostra la figura sottostante. 



Figura 2: Struttura funzionale interna 


La tabella riporta i valori limiti di pressione associati alla temperatura, per cui si ha il 
danneggiamento o una degradazione rispetto al normale funzionamento. 


Parametrics 

Symbol 

Value 

Unit 

Overpressure* 2 * (PI > P2) 

P max 

400 

kPa 

Burst Pressure* 2 * (PI > P2) 

P burst 

1000 

kPa 

Storage Temperature 

^stg 

-40*10+125' 

°C 

Operating Temperature 

Ta 

-40°to+125° 

°C 


1. T c = 25°C unless otherwise noted. 

2. Exposure beyond thè specified limits may cause permanerò damage or degradation to thè device. 


Tabella 1 : Va lo ri limiti 
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C bara età rlstic 

Symbol 

Min 

Typ 

Max 

Unlt 

Pressure Range* 1 * 

Pop 

15 

- 

115 

kPa 

Suppty Voltage* 2 * 

Vs 

4.85 

5.1 

5.35 

Vdc 

Suppty Current 

le 

— 

7.0 

10 

mAdc 

Minimum Pressure Offset* 3 * (0 to 85°C) 

@ V s = 5.1 Volts 

Volt 

0.135 

0.204 

0.273 

Vdc 

Fui Scale Outptx(4) jq (q 85°C) 

@ V s = 5.1 Volts 

Vfso 

4.725 

4.794 

4.863 

Vdc 

Fui Scale Span(5) (0 to 85°C) 

@ V s = 5.1 Volts 

V FSS 

— 

4.59 

— 

Vdc 

Accuracy* 6 * (0 to 85°C) 

— 

— 

— 

±1.5 

%V F gg 

Sensitlvity 

V/P 

— 

46 

— 

mV/kPa 

Responso Time* 7 * 


— 

1.0 

— 

ms 

Output Source Current at Full Scale Output 

lo* 

— 

0.1 

— 

mAdc 

Warm-Up Time* 8 * 

— 

— 

20 

— 

mSec 

Offset Stability* 9 * 

— 

— 

±0.5 

— 

%V F5S 


1. 1 OkPa (klioPascal) equals 0.145 psi. 

2. Device is ratio metric within this specified exatation range 

3. Offset (V^) Is defined as thè output voltage at thè minimum rated pressure. 

4. Full Scale Output (V FS0 ) is defined as thè output voltage at thè maximum or full rated pressure. 

5. Full Scale Span (V FSS ) is defined as thè algebraic difference between thè output voltage at full rated pressure and thè output voltage at thè 
minimum rated pressure. 

6. Accuracy (error budget) consists of thè following: 

Llnearity.Output deviation from a straight line relationship with pressure, using end polnt method. over thè specified pressure range. 
Temperature HysteresisiOutput deviation at any temperature within thè operatlng temperature range. after thè temperature Is cyded to and 
from thè minimum or maximum operatlng temperature polnts, with zero differential pressure applied. 

Pressure Hysteresls:Output deviation at any pressure within thè specified range. when this pressure Is cycled to and from thè 
minimum or maximum rated pressure at 25°C. 

TcSpan:Output deviation over thè temperature range of 0° to 85°C. relative to 25°C. 

TcOffset Output deviation with minimum pressure applied. over thè temperature range of 0* to 85*C. relative 
to 25*C. 

Variation from NominakThe varlation from nominai values. for Offset or Full Scale Span. as a percent of V F $s et 25°C. 

7. Responso Time is defined as thè time for thè Incrementai change in thè output to go from 10% to 90% of its final value when subjected to 
a spedfied step change In pressure. 

8. Warm-up is defined as thè tane required for thè produd to meet thè spedfied output voltage after thè Pressure has been stabllized. 

9. Offset stability is thè producfs output deviation when subjected to 1000 hours of Pulsed Pressure, Temperature Cycling with Bias Test. 

La tabella riporta le caratteristiche operative del sensore in condizioni di normale 
funzionamento. 


Tabella 2: Caratteristiche operative del dispositivo 


Il collegamento elettrico del sensore deve avvenire secondo lo schema sotto riportato. I 
due condensatori presenti sulla linea di alimentazione hanno lo scopo di filtrare il rumore 
presente su tale linea(di solito lOOnf multistrato e 1 .Ous al tantalio). 

È comunque necessario, dal momento che abbiamo a che fare con un sensore analogico, 
separare l’alimentazione e la massa di questo dal resto del circuito.Ciò può avvenire, nella 
fase realizzativa del pcb, predisponendo una alimentazione analogica ed una massa 
analogica, che per esempio chiameremo AVcc e AGnd. 

Queste due linee dovranno essere splittate, con l’alimentazione generale e la massa 
generale, in prossimità dell’alimentatore del sistema, che rappresenta il punto ad 
impedenza più bassa presente nel circuito. 
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+5.0 V 



Figura 3: Collegamento elettrico del sensore 


La relazione che esprime la tensione di uscita in funzione della pressione misurata, è data 
da: 


V ou t=Vs*(0.009*P-0.095) 

in cui Vs è il valore della tensione analogica di alimentazione e P è la pressione rilevata in 
Kpascal. 

Le relazioni che legano i Kpascal ai millibar e ai Torricelli sono: 

mbar=Kpa*10 

Torr=Kpa*7.5006 


È quindi possibile ricavare la V ou t in funzione di queste nuove unità di misura, ed avremo: 
V out =Vs*(0.009* mbar/10 -0.095) 

V ou t=Vs*(0.009*Torr/7.5006 -0.095) 


Ipotizzando Vs=5.0v mediante il foglio elettronico Excel è possibile ricavare la 
caratteristica di trasferimento del sensore in Kilopascal, millibar e Torricelli, come mostrano 
le figure sottostanti. 
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A 

B 

C 

D 

E 

F 

1 

«pascal 

Risposta sensore MPX4115(V-Kpa) 

millibar 

Risposta Sensore MPX411S(V-mbar) 

Torricelli 

Risposta sensore MPX4115(v-Torr) 

2 

15 

0,204 

150 

0,204 

112,51 

0,204 

3 

20 

0,434 

200 

0,434 

150,01 

0,434 

4 

25 

0,663 

250 

0,663 

187,52 

0,663 

5 

30 

0,893 

300 

0,893 

225,02 

0,893 

6 

35 

1,122 

350 

1,122 

262,52 

1,122 

7 

40 

1,352 

400 

1,352 

300,02 

1,352 

8 

45 

1,581 

450 

1,581 

337,53 

1,581 

9 

50 

1,811 

500 

1,811 

375,03 

1,811 

10 

55 

2,040 

550 

2,040 

412,53 

2,040 

11 

60 

2,270 

600 

2,270 

450,04 

2,270 

12 

65 

2,499 

650 

2,499 

487,54 

2,499 

13 

70 

2,729 

700 

2,729 

525,04 

2,729 

14 

75 

2,958 

750 

2,958 

562,55 

2,958 

15 

80 

3,188 

800 

3,188 

600,05 

3,188 

16 

85 

3,417 

850 

3,417 

637,55 

3,417 

17 

90 

3,647 

900 

3,647 

675,06 

3,647 

18 

95 

3,876 

950 

3,876 

712,56 

3,876 

19 

100 

4,106 

1000 

4,106 

750,06 

4,106 

20 

105 

4,335 

1050 

4,335 

787,56 

4,335 

21 

110 

4,565 

1100 

4,565 

825,07 

4,565 

22 

115 

4,794 

1150 

4,794 

862,57 

4,794 


Figura 4: Caratteristica di trasferimento del sensore 



Figura 5: Risposta del sensore MPX4115(V-Kpa) 
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Figura 6: Risposta del sensore MPX4115(V-mbar) 


Risposta MPX4115(V-Torr) + 



Figura 7 : Risposta del sensore MPX4115(V-Torr): Il fattore di errore dovuto alla 
temperatura di esercizio e quello relativo alla misura della pressione sono riportati nelle 

figure seguenti. 
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Temperature Error Band 


MPX4115A Series 


Temperature 

Errar 

Factor 



r Pressure Errar Band 


9.0 
6.0 
& 3.0 

^ 0.0 

1 40 

• 6.0 


1. -ll-l-l-l-U 1.L ■■Ll.1.,.1.1 .1.1,1.1.1. 


10 20 30 40 50 60 70 80 90 100 110 120 


Pressure (in kPa) 


-9.0- 

Pressure 

Error (Max) 


15to 115 (kPa) 

±1.5 (kPa) 


Figura 8-9: Fattore di errore temperatura e pressione 

Si nota che il fattore di errore dovuto alla temperatura resta constante nell’intervallo di 
temperatura (H85 C°, per crescere linearmente, con la stessa pendenza, al disotto dello 0 
C° e al disopra dei 85 C°. Questo dimostra che l’errore minimo è commesso dal dispositivo 
nell’intervallo di temperatura CK85C°,che deve essere l’intervallo di operatività per il 
sensore. 


Il Firmware di interfacciamento 

Dal momento che userò l’oscillatore interno del PIC18F45K22 è necessario impostare in 
modo corretto i fuses del microcontrollore,per far ciò, usando il compilatore 
MikroC,troveremo queste impostazioni nel pannello Edit Project.La corretta impostazione è 
riportata nella figura seguente. 
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Impostazione fuses 



Intcmal/f xtcmal Owbtor Switrhovrr 

OsaWed v 


Conftguation Reiteri 


Power up Timer 

Deabicd v 

Brownout Rncl 

Brown-out Reset enabled n hardware onty (S80REN e dsabted) v 

Brown Out Reset Voltale 

'iBOR set lo 1.90 V norma* _w 

Watchdog Timer 

Deabied v 


CONFICI» 

*300001 

0x0028 

CONFIG?L 

*30000? 

OxOOlF 

CONFIG?» 

*300003 

0x003C 

CONFIC3H 

*30000* 

OxOOBF 

CONFIG*L 

$300006 

0x0081 

CONFICSL 

*300003 

0x000F 

CONFICSH 

*300003 

0x0OCO 

CONFIG6L 

$30000* 

OxOOOF 

CONFIG*» 

*30000B 

OxOOZO 


Load Scherne 
Save Schema 


E.efault 


Watchdog Timer Postscale 

1:32768 v 


£K 


CCP2 MUX bit 

CCP2 rput/output s muiapiexed mth RC1 V 


Generai Output Settingt 


i»ncei 





Figura 10:impostazione fuses oscillatore interno 


Le impostazioni per utilizzare l’oscillatore interno devono essere inserite anche nel 
programma principale, ed in modo particolare subito dopo la dichiarazione della funzione 
main come riporta la figura sottostante. 


Impostazione oscillatore interno 

void main() 

{ 

// Settaggio oscillatore interno a 8mhz 
OSCCON = ObOllOOOOO; // bit7: device enters SLEEP on sleep instruction[0] 

// bit6-4: HFINTOSC 16MHz [111] 8MHz[110] 

// bit3: status bit [0] 

// bit2: status bit [0] 

// bitl-0: clock defined by CONFIG bits [00] 

// Abilitazione del PLL x4 Fosc vale a dire 64Mhz Fosc 
OSCTUNE = OblOOOOOOO; // bit7: device clock derived from thè MFINTOSC or HFINTOSC source 

// bit6: PLL enabled [1] 

Figura 11:oscillatore interno 


Come ingresso analogico userò il pini della Porta A, configurando il convertitore ADC in 
modo che le sue tensioni di riferimento siano coincidenti con quelle di alimentazione del 
sistema. L’allineamento dei dati di conversione avverrà partendo da destra e con un tempo 
di acquisizione di 8 Tad(periodo del clock del convertitore),tale tempo è riferito al Tracking 
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and Hold interno del PIC.Per quanto riguarda la frequenza di lavoro dell’ ADC questa 
dovrà risultare essere la frequenza dell’oscillatore interno divisa per 32.Come mostra il 
listato 1. 


Listato 1 

: ANSELA.Bl=l; // ingresso analogico per MPX4115 

TRI SA. Bl =1; //- 

://-configurazione del convertitore ADC- 


ADCON0 . <30=0 ; 

// 

no start conversion 

ADCON0.ADON=l; 

// 

attivo convertitore ADC 

ADCONl. B3=0 ; 

// 

Vref-=VDD 

ADCONl.B2=0; 

// 


ADCONl.Bl=0; 

// 

Vref-=VSS 

ADCONl.B0=0; 

// 


ADCON2.ADFM =1 ; 

// 

allineamento a destra 

ADCON2.ACQT2=1; 

// 

tempo di acquisizione Sampie/Hold 

ADCON2.ACQT1=0; 

// 

8 TAD 

ADCON2.ACQT0=0; 



ADCON2.ADCS2=0; 

// 

fattore di divisione clock 

ADCON2.ADCS1=1; 

// 

Fosc/32 

ADCON2.ADCS0=0; 




Le funzioni utilizzate per la lettura e la visualizzazione del dato relativo alla pressione(in 
Torr) misurata sono due, la prima(Conversione_Adc()) permette di selezionare il canale di 
acquisizione,mentre la seconda(Legge_Pressione()) calcola la pressione e consente di 
visualizzare il dato su Lcd. In quest’ultima funzione è presente nel suo interno la funzione 
printfloat_lcd() che permette la visualizzazione della pressione sull’ Lcd,tale funzione è una 
libreria personale aggiunta al compilatore ma basterà modificare il programma per 
adattarlo alle librerie standard del compilatore.Vedi listato 2,3,4. 


Listato 2 

void Conversione Ade (unsigned char canale); 

void Legge Pressione (unsigned char Rade var, float Press var, 

unsigned int Press Int var, 
unsigned char Lcd Text vect); 
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Listato 3 

void Conversione Ade (unsigned char canale) 

{ 

ADCONO.CHS4=canale.B4; 

ADCONO.CHS3=canale.B3; 

ADCONO.CHS2=canale.B2; 

ADCONO.CHSl=canale.Bl; 

ADCONO.CHSO=canale.BO; 

} 


Listato 4 

void Legge Pressione (unsigned char Rade var, float Press var, 

unsigned int Press Int var, 
unsigned char Lcd Text vect) 

{ 

Go bit=l; 
while (Go bit=l) 

{ 


asm { 


} 


nop; 


} 

Radc= ( (ADRESH«8) +ADRESL) ; 

Press=( (7 . 5/0 . 009) *(( (4 . 88e-03*Radc)/5 . 0)+0 . 095) ) -10 ; 
floatToStr(Press,buffer); 
printfloat lcd (3 , 16 , 5 ,buffer); 

Press Int=Press; 


Lo schema elettrico del progetto, così come la simulazione, sono stati realizzati utilizzando 
il programma professionale Proteus 7.10.1 risultati così ottenuti sono stati conformi alla 
verifica sperimentale usando la EasyPic7.Osservando in fase di simulazione le tensioni 
misurate dal voltmetro collegato in uscita dal sensore,si sono potuti incrociare i dati 
calcolati facendo uso del foglio elettronico EXCEL, ben visibili in figura 4. 
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Proteus 7.10 SPO 


RAO/C121NO-/ANO R C0/P2 B/T3 CKI/T3 O/T 1CKI/S OSCO 

RAI/CI 21 NI-/ANI RC1/P2A/CCP2/SOSCI 

RA2/C2IN+/AN2/DACOUTA/REF- RC2/CTPLS/P1A/CCP1/T5CKI/AN14 

RA3/C1IN+/AN3/VREF+ RC3/SCK1/SCL1/AN15 

RA4/C1OUT/SRQ/TOCKI RC4/SDI1/SDA1/AN10 

RA5/C20UT/SRNQ/SS1/HLVDIN/AN4 RC5/SD01/AN17 

RA6/C LKO/O S C2 RC6/TX1/CK1/AN18 

RA7/CLKI/OSC1 RC7/RX1/DT1/AN19 


R DO/S C K2/S C L2/AN20 
RD1/CCP4/SDI2/SDA2/AN21 
RD2 /P2B/ AN22 
R D3/P2 C/S S2/AN23 
R D4/P2 D/S D 02/AN24 
RD5/P1B/AN25 
R D6/P1C/TX2/C K2/AN26 
RD7/P1D/RX2/D T2/AN27 


R BO/IN TO/F LTO/S RI/AN12 
RB1/INT1/C12IN3-/AN10 
R B2/IN T2/CT E D1/A« 

RB3/CTE D2/P2A/C C P2/C121N2-/AN9 

RB4/IOC0/T5O/AN11 

R B5/IO C1/P3A/C C P3/T3 C Kl/T 1G/AN13 

RB6/IOC2/PGC 

RB7/IOC3/PGD 


R E0/P3 A/C C P3/AN5 
RE1/P3B/AN0 
R E2/C C P5/AN7 
MCLR/V/PP/RE3 


PIC18F46K22 




PROTEUS 

The Complete Electronics Design System 


Figura 13: Simulazione del progetto 



Figura 12: Schema elettrico del progetto 
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IL firmware del progetto, così come i file, del foglio elettronico Excel e della simulazione 
mediante Proteus 7.10, sono direttamente scaricabili dal sito dell’editore. 

Una volta scaricati i file,per poter compilare di nuovo il programma sarà necessario 
modificarlo riscrivendo le seguenti funzioni, non presenti nelle librerie standard del 
compilatore. 


Lcd_Stringa(.); 

PrintfloatJcd(.); 


Se qualche lettore trovasse difficile fare questo lavoro di riscrittura, sarò ben lieto di 
metterle a sua disposizione, previo avvisare l’editore, che in questo caso farà da tramite. 


La foto sotto riportata mostra il funzionamento del sensore MPX4115AP inserito in un 
contesto di una semplice stazione metereologica, che trasmette i dati via infrarosso 
utilizzando la modulazione OOK, oggetto di un successivo articolo.La pressione 
visualizzata, di 721.7 Torr, è legata ad una giornata non molto serena e all’altitudine in cui 
la misura è stata effettuata, di circa 300 m sul livello del mare. Ricordo che il sensore 
fornisce una misura di pressione assoluta. 



Immagine 1: Semplice stazione meteo 
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Osservazioni finali: 

In commercio è presente l’integrato LPS331AP della STMicroelectronics che è un sensore 
di presssione piezoresistivo,in grado di misurare una pressione assoluta(26CM260mbar) e 
risulta essere di tipo digitale. Possiede due protocolli di comunicazione ed esattamente, 
SPI e I2C,selezionabili via hardware mediante ponticelli.IL sensore può essere letto sia in 
polling che in interrupt in quanto dotato della linea INT(interruzione).La tensione massima 
di alimentazione e di 3.3V. 

Utilizzando EasyPIC7, la Mikroelektronica fornisce il sensore già montato e sfrutta il 
formato mikroBus presente sulla scheda, prendendo il nome di:”Pressure click”,ma può 
essere montato in modo stand alone su una qualsiasi board . 


Schema elettrico pressure click riferito al mikroBus 
Pressure Click™ Board Schematic 



Figura 14: Pressure click 
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Infine riporto le dimensioni del sensore MPX4115AP con relativi pin di collegamento. 

Dimensioni e pin di collegamento 



NOTES: 

1. DIMENSIONS ARE IN MILUMETERS. 

2. DIMENSIONS AND TOLERANCES PER ASME Y14.5M-1994. 

3. 867B-01 THRU -3 OBSOLETE. NEW STANDARD 867B-04. 


STYLE 1: 

PIN 1: V OUT 
2: GROUND 
3: VCC 
4: VI 
5: V2 

6: V EX 


Figura 15:Dimensioni e pin 


Elenco componenti 

CI 

lOOnf multistrato 

C2 

luF 25 V Tantalio 

U1 

PIC18F45K22 

LCD 

20x4 Hitachi 

Sensore 

MPX4115AP 
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Sensori di pressione e umidità 

Scopo di questo articolo è quello di offrire una panoramica sui sensori di pressione ed 
umidità, largamente utilizzati in svariati tipi di applicazioni nel settore dell’automazione 
industriale, del controllo di processo, nella domotica, nel settore automotive e 
nell’elettronica di consumo 

Introduzione 

I sensori di pressione ed umidità rivestono un ruolo importante in molte applicazioni con le 
quali interagiamo quotidianamente. La misura di pressione è infatti richiesta, ad esempio, 
per rilevare la presenza di fluidi, liquidi, e gas aH’interno dei circuiti idraulici, per rilevare 
l’altitudine, per determinare la portata di un fluido, per realizzare sistemi TPMS (Tire 
Pressure Monitoring System) sulle autovetture, per sistemi di misura nel campo 
biomedicale, eco. I sensori di umidità hanno invece quali potenziali applicazioni le 
seguenti: impianti di refrigerazione e asciugatura, stazioni meteorologiche, sistemi di 
condizionamento ed umidificazione, domotica, apparecchiature medicali. 

La misura della pressione 

Anzitutto occorre definire i tre tipi fondamentali di misura della pressione, dato che i 
datasheet dei vari sensori disponibili sul mercato fanno riferimento a questo tipo di 
teminologia: 

• pressione assoluta: è la pressione misurata assumendo come riferimento il vuoto, 
quindi la pressione nulla. Un esempio di pressione assoluta è fornito dalla 
pressione atmosferica, mentre un esempio di unità di misura utilizzata per questa 
pressione è il PaA (Pascal Absolute) 

• pressione relativa (indicata in inglese con la notazione gauge pressure): è la 
pressione misurata rispetto alla pressione atmosferica. Un esempio di pressione 
relativa è rappresentato dalla pressione sanguigna, mentre un esempio di unità di 
misura utilizzata per questa pressione è il PaG (Pascal Gauge) 

• pressione differenziale: è la pressione misurata rispetto ad una pressione di 
riferimento. Si può pertanto osservare come la pressione relativa sia un caso 
particolare di pressione differenziale. Un’unità di misura utilizzata per questa 
pressione è ad esempio il PaD (Pascal Differential) 

I tre tipi di misura della pressione sono rappresentati in figura 1. 


GAUGE 
PRESSUREi 

: J 

DIFFERENTIAL 
\ PRESSURE 1 a(m< 

14.7 osia 

i 

k 

ABSOLUTE 
r PRESSURE 

r (1 naia 

(PER FECTVACUUM) 


Figura 1: i tre tipi di misura della pressione 
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Tipologie di sensori di pressione 

I sensori di pressione si prestano per essere impiegati in molteplici tipi di applicazioni nel 
campo deN’industria, deN’automazione, nel settore automotive, nelle apparecchiature 
biomedicali, e nell’elettronica di consumo in generale. I sensori di pressione integrati si 
possono classificare in tre tipologie, tutte con la caratteristica comune di possedere una 
membrana che si deforma per effetto della pressione su di essa esercitata: 

• sensori di pressione piezoresistivi, basati sulla variazione di resistività di un 
materiale conduttore prodotta dalla deformazione della membrana 

• sensori di pressione capacitivi, basati sulla variazione di capacità prodotta dal 
movimento della membrana 

• sensori di pressione risonanti, basati sulla variazione della frequenza di risonanza 
di un materiale posto sulla membrana, prodotta come effetto della deformazione 
della stessa 

Sensori di pressione piezoresistivi 

Sono caratterizzati dal possedere un’uscita che varia linearmente con la pressione 
applicata, da un’elevata impedenza di uscita, da un costo e da una complessità di 
realizzazione relativamente bassi. Per contro, presentano lo svantaggio di essere poco 
sensibili, quindi non particolarmente adatti alla misura di basse pressioni, oltre alla 
dipendenza della misura dalla temperatura (per cui possono richiedere, se necessario, 
un’azione di compensazione della stessa). Questi sensori utilizzano in genere dei resistori 
realizzati in silicio monocristallino, particolarmenti adatti per realizzare dispositivi ad 
elevata integrazione, e caratterizzati da un elevato fattore di misura e alta sensibilità. I 
resistori sono solitamente connessi in configurazione a ponte di Wheatstone (linearità 
dell’uscita) ma, come già evidenziato, esiste una dipendenza della loro resistività dalla 
temperatura. Le tecnologie elettroniche di fabbricazione adottate per la loro costruzione 
prevedono il micromachining, il surface blonding, e il surface-micromachining. Inoltre, 
questi sensori sono adatti a misurare variazioni di pressione, piuttosto che pressioni 
statiche. I sensori piezoresistivi sono adatti alle misure di pressione assoluta, relativa, e 
differenziale, 

Come esempio di sensore di pressione piezoresistivo prendiamo la serie MPX2010 di 
Freescale, capace di misurare pressioni fino a 75kPa (lOOkPa in modalità burst), con 
compensazione della temperatura e calibrazione dell’offset. La serie MPX2010 comprende 
sensori piezoresistivi realizzati in silicio in grado di fornire una tensione di uscita accurata e 
lineare, direttamente proporzionale alla pressione applicata. I sensori ospitano al loro 
interno un singolo blocco monolitico di silicio con integrata una sottile rete di resistori e 
capace di misurare le deformazioni (tensioni meccaniche) prodotte. I sensori sono inoltre 
regolati tramite laser per offrire una lunga durata, calibrazione dell’offset, e compensazione 
della temperatura nel range compreso tra 0°C e +85°C. I sensori della serie MPX2010 
sono adatti alla misura di pressioni differenziali e relative, con applicazioni nel campo della 
diagnosi medica (soprattutto per le patologie di tipo respiratorio), nel controllo del 
movimento del flusso d’aria, nei sensori di pressione in generale. In figura 2 è mostrata la 
curva caratteristica di questo sensore; sull’asse orizzontale è riportata la pressione 
applicata al sensore, mentre sull’asse verticale la tensione in uscita dallo stesso. La curva 
è riferita alla temperatura di riferimento di 25°C. Si notino sia la linearità perfetta della 
curva, che il valore di offset, molto contenuto. In figura 3 è mostrato un esempio di sensore 
MPX2010 (esitono molte versioni con contenitori differenti): i quattro pin corrispondono alla 
tensioni di uscita (+VOUT e -VOUT), alla tensione di alimentazione VS e alla massa. 
Questo sensore è dotato inoltre di doppia porta per la misura della pressione: una 
corrisponde alla pressione positiva e l’altra alla pressione di riferimento del vuoto. 
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Span 

Range 

(Typical) 


:_L 


kPa 2.5 5 7.5 10 

PSI 0.362 0.725 1.09 1.45 

Figura 2: linearità di un sensore piezoresistivo 


Offset 

(Typical) 



Figura 3: un sensore della famiglia MPX2010 

Sensori di pressione capacitivi 

Rispetto al precedente tipo, i sensori capacitivi sono caratterizzati da una maggiore 
sensibilità, una minore dipendenza della misura dalla temperatura, e da un assorbimento 
ridotto. Tra gli svantaggi vanno menzionati la non linearità dell’uscita e la presenza di 
capacità parassite che possono influenzare negativamente la misura. Il condensatore ha 
un’armatura fissa, solidale con il substrato del materiale adottato per la sua fabbricazione, 
e l’altra, mobile, solidale con la membrana; le deformazioni subite da quest’ultima 
generano pertanto delle variazioni di capacità sulle armature del condensatore. Le 
tecnologie elettroniche impiegate per la loro fabbricazione sono il fusion-bonding e il 
surface-micromachining. Questi sensori richiedono un circuito elettronico addizionale in 
grado di leggere il valore di capacità e ricavare da questo la misura di pressione 
corrispondente. Nei casi più semplici può essere un circuito a componenti discreti, fino ad 
arrivare ad un vero e proprio processore dedicato. Il valore di capacità è compreso tra 
pochi picofarad fino a circa 50-100 pF. Questi sensori sono particolarmente adatti alla 
misura di piccole pressioni, sia assolute che differenziali e relative. 

Come esempio di sensore di pressione capacitivo si consideri il modello KP106 prodotto 
da Infineon, visibile in figura 4. Il sensore è stato progettato per impieghi automotive, in 
particolare per rilevare gli urti laterali e pertanto viene installato in un modulo aN’interno 
delle portiere laterali. Quando la portiera si comprime a seguito di un impatto laterale, il 
sensore KP106 genera un segnale con ampiezza proporzionale alla variazione di 
pressione che si genera all’interno della portiera. Il segnale di uscita, indipendente dalla 
pressione ambiente, viene poi trasmesso alla ECU per attivare il relativo airbag. 
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Figura 4: il sensore KP106 di Infineon 


Sensori di pressione risonanti 

Questa tipologia di sensori è contraddistinta da un’elevata risoluzione e precisione della 
misura, con un’uscita funzione dalla frequenza di risonanza. Lo svantaggio principale 
deriva essenzialmente dalla complessità realizzativa del sensore, che incide 
negativamente anche sul loro costo. Vanno inoltre considerate la non linearità del sensore 
e la sensibilità alla temperatura e alle vibrazioni. Per ricavare il valore di pressione 
partendo dalla frequenza di risonanza del sensore si utilizza solitamente un circuito 
oscillatore elettronico. In figura 5 è mostrato un esempio di sensore di pressione risonante, 
l’RTC350 prodotto da General Electric. Trattasi di un sensore caratterizzato da un’elevata 
stabilità (lOOppm per anno) e da un’elevata accuratezza (0,001%). Il range di pressioni è 
compreso tra 35 e 3500 mbar assoluti, mentre l’uscita è in frequenza su un’interfaccia di 
tipo RS232/485. 



Figura 5: il sensore RTC350 di GE 


La misura dell’umidità 

Con il termine umidità si intende la quantità di vapore acqueo contenuta nell’aria o in altri 
gas. L’umidità può essere misurata in vari modi e con diverse unità di misura; le tre più 
comunemente usate sono: umidità assoluta, umidità relativa (RH), e dew point (punto di 
rugiada). 
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Umidità assoluta 

È definita come il rapporto tra la massa di vapore acqueo ed il volume di aria o gas che lo 
contiene. Viene solitamente espressa in grammi per metro cubo. 

Punto di rugiada 

È definito come la temperatura e pressione alle quali il gas comincia a condensarsi in 
liquido ed è espressa in °C o °F. 

Umidità relativa 

È definita come il rapporto (in percentuale) della pressione parziale del vapore acqueo 
contenuto in un miscuglio gassoso di aria e vapore acqueo rispetto alla pressione di vapor 
saturo, espressa in percentuale. Un'umidità relativa del 100% indica che il miscuglio 
gassoso contiene la massima quantità di umidità possibile per le date condizioni di 
temperatura e pressione. 

Tipologie di sensori di umidità 

I sensori di umidità possono essere classificati in tre categorie: sensori di umidità 
capacitivi, sensori di umidità resistivi, e sensori di umidità termici (o sensori di umidità 
assoluta). 

Sensori di umidità capacitivi 

Sono ampiamenti utilizzati nelle applicazioni industriali, commerciali, e in meteorologia, e 
misurano soprattutto l’umidità relativa. Sono composti da due elettrodi conduttivi, 
aN’interno dei quali è presente un substrato (vetro, ceramica, o silicone) sul quale è 
depositata una sottile pellicola di ossido metallico. La variazione incrementale di costante 
dielettrica di un sensore di umidità capacitivo è all’incirca direttamente proporzionale 
aN’umidità relativa presente neN’ambiente. La variazione di capacità è dell’ordine di 0,2-0,5 
pF per una variazione di RH dell’1%, mentre la capacità complessiva a 25°C e 50% RH è 
compresa tra 100 e 500 pF. Questi sensori hanno un basso coefficiente di temperatura, 
resistono alle alte temperature, e sono resistenti agli agenti tossici. I tempi di risposta sono 
compresi tra qualche secondo e qualche decina di secondi. Come esempio di sensore di 
umidità capacitivo si consideri il modello HS1101, mostrato in figura 6. Si tratta di un 
sensore basato su una cella capacitiva in grado di misurare l’umidità relativa con 
un’accuratezza pari a ±5% ed un tempo di risposta inferiore a 5 secondi. È molto semplice 
da interfacciare con vari modelli di microcontrollore, oppure con un semplice circuito RC. 



Figura 6: il sensore HS1101 


Sensori di umidità resistivi 

I sensori di umidità resistivi misurano la variazione di impedenza di un materiale 
igroscopico, come un polimero conduttivo, sale, oppure un substrato opportunamente 
trattato. La variazione di impedenza è inversamente proporzionale aN’umidità: quanto più 
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alta è l’umidità, minore è la resistenza e quindi maggiore sarà la tensione in uscita. I 
sensori resistivi sono solitamente composti da elettrodi realizzati con metalli nobili 
depositati su un substrato rivestito con un sale o con un polimero conduttivo. Il sensore 
assorbe il vapore acqueo che provoca una dissociazione dei gruppi ionici con un 
conseguente aumento della conducibilità elettrica. Il tempo di risposta per la maggiorparte 
dei sensori resistivi varia tra 10 e 30 secondi, mentre l’impedenza è compresa tra 1 kQ e 
100 MQ. Come esempio di sensore di umidità di tipo resistivo consideriamo il modello 
SYH-1 prodotto da Samyoung (visibile in figura 7), in grado di offrire un’accuratezza pari a 
±3%RH a 25°C ed un tempo di risposta inferiore a 60 secondi. In figura 8 è mostrata la 
curva caratteristica del sensore, dalla quale si evince come la resistenza, espressa in kQ, 
sia inversamente proporzionale aN’umidità relativa. Un pregio di questo sensore è quello di 
presentare una curva pressoché lineare, cosa che agevola la misura deN’umidità relativa 
eseguita tramite microcontrollore e firmware opportuno. 

SYH-1 S SYH-2S 

Figura 7; il sensore SYH-1 
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Figura 8: caratteristica del sensore SYH-1 

Sensori di umidità assoluta 

Questi tipi di sensori misurano l’umidità assoluta quantificando la differenza tra la 
conduttività termica deN’aria secca e quella deN’aria contenente vapore acqueo. I sensori 
di questo tipo sono in grado di lavorare anche ad elevate temperature e possono pertanto 
essere utilizzati in applicazioni dove i sensori capacitivi e resistivi non sopravvivrebbero. 
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Figura 9: il sensore ABS-FS11 


L’accuratezza è dell’ordine di +3g/m3, corrispondente a circa ±5%RH a 40°C e ±0,5%RH a 
100°C. Come esempio di sensore di umidità assoluto si consideri il modello ABS-FS11 
prodotto da Hygrosens Instruments (figura 9), un sensore in grado di lavorare fino a 200°C 
ed estremamente robusto. È particolarmente indicato per applicazioni quali processi di 
asciugatura industriali, forni, condizionatori, analisi dei gas, forni a microonde. Il tempo di 
risposta è inferiore a 16 secondi, mentre il range di umidità assoluta misurabile è 
compreso tra 0 e 130 g/m3. Il sensore è composto da due NTC identiche, connesse in 
serie, attraverso le quali viene fatta passare una corrente tale per cui le NTC raggiungono 
una temperatura di 300°C per autoriscaldamento. Un NTC è posta in una cella contenente 
il gas di riferimento (azoto, corrispondente alla condizione di aria secca), mentre l’altra 
NTC è posta in una cella collegata con l’ambiente esterno. A seconda della conduttività 
termica del gas da misurare, si genererà una differenza di potenziale tra le due celle e 
questa è una misura della concentrazione del gas rispetto al gas di riferimento. 
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CONTROLLO ACCESSI CON PIC 

di Giovanni Di Maria 

II controllo degli accessi ai dispositivi è oggi un'operazione molto semplice grazie alla 
tecnlogia messa a disposizione da MikroElektronica. 


RFid Reader è una scheda che ha lo scopo di leggere le Identification Cards (RFid Cards) 
con il supporto delle onde radio. Tale scheda funge da modulo ricevente e trasmittente 
tramite antenna, ed è corredata da un connettore maschio 2x5 per permetterne la 
connessione ad un sistema di sviluppo. 


Cos'è RFid 

Radio frequency identification (RFID) è una tecnologia di un sistema capace di trasmettere 
l'identità (solitamente un numero seriale univoco) di una persona, animale o oggetto, 
usando le onde radio. 

Tale tecnologia è molto utilizzata. Si pensi, ad esempio, ad un cane provvisto di chip, per il 
suo riconoscimento e tracciabilità. 

In più tale tecnologia è resa ancor più sicura, adottando anche metodologie e applicazioni 
biometriche. 

Diversamente dai lettori a codici a barre, questa tecnologia non richiede un contatto fisico 
e diretto. I dati possono anche essere letti attraverso il corpo umano ed altri tipi di ostacoli. 


Componenti RFid 

Ecco a grandi linee i componenti principali di un sistema RFid: 

• L'antenna, che emette onde radio, attivando il trasponder. Quindi legge ed invia 
informazioni a quest'ultimo; 

• Il reader, che trasmette i segnali anche a parecchi metri, secondo la potenza 
irradiata; 

• Il tag o trasponder, che nelle vicinanze del reader si attiva. 



Trasponder 



Reader 


Computer 



Figura 1: Principio della tecnologia RFid 
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Figura 2: Esempio di utilizzo RFid 
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Figura 3: Smart card RFid 


Applicazioni 

Molteplici sono le applicazioni in cui si utilizza la tecnologia RFid, ed il numero di esse 
incrementa sempre più, con il passare del tempo. A grandi linee ecco i settori di principale 
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utilizzo: 


• Produzione 

• Vendita al dettaglio 

• Sistemi di pagamento 

• Controllo e sicurezza 

• Controllo accessi 

• Trasporti 

• Carte di credito 

• Controllo presenze 

• Assistenza e manutenzione 

• Identificazione degli animali 

• Biblioteche 

• Antitaccheggio 

• Registro Scolastico Elettronico 

• Monitoraggio raccolta rifiuti 

• Bigliettazione Elettronica 

• Logistica Magazzini 

• E tanti altri... 


RFid Reader Board della MikroElektronica 

RFid Reader è una scheda prodotta dalla MikroElektronika, utilizzata per leggere le 
Identification Cards (RFid Cards) tramite onde radio. Essa funziona da ricevente e 
trasmittente tramite antenna. Puà essere connessa ad un sistema di sviluppo (tipo Easy 
Pie 5) per mezzo di un connettore maschio 2x5. 

Il suo funzionamento si basa su due princìpi fondamentali: 

x L'amplificazione della modulazione delle onde radio; 

A L'induzione elettromagnetica. 


In dettaglio 

RFid Reader è costituita dalle seguenti componenti: 

x Un connettore maschio (2x5) che permette il collegamento ad una scheda di 
sviluppo (tipo Easy Pie 5). I collegamenti prevedono i segnali di alimentazione (Vcc 
e Gnd) e naturalmente l'accesso al bus delle porte di un pie (ad esempio: RBO, 
RB1, RB2, RB3, RB4, RB5, RB6, RB7); 

x II Transceiver EM4095 che è utilizzato quale modulatore e demodulatore AM e 
anche come driver per antenna; 

^ L'antenna vera e propria, “stampata” sulla scheda, che riceve i segnali provenienti 
dalla RFid Card. 
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Figura 4: Il lettore RFid 



Figura 5: Il lettore Rfid (vista posteriore) 



Figura 6: La connessione ad un sistema di sviluppo 
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Antenna 


Figura 1: L'antenna integrata 



Figura 8: Schema di principio 

RFid Reader è alimentato quando il sistema di sviluppo (ad es: Easy Pie 5) è collegato ad 
esso. La presenza di alimentazione sul Reader è indicata da un diodo led (Power). Non 
appena il modulo viene acceso, l'antenna riceve una tensione alla frequenza di 125 Khz 
ed emette un campo elettromagnetico atto a leggere le Identification Cards. 


Algoritmi di sicurezza 

RFid Reader dispone di alcuni sofisticati algoritmi per evitare problemi o errori nella lettura 
dei dati a distanza. In particolare: 

^ Introduce un sistema logico algoritmico di Anti Collisione, grazie al quale è possibile 
la lettura simultanea anche di un numero elevato di Identification Cards, il tutto privo 
di qualsiasi tipo di errore; 

^ Include anche un sofisticato sistema per cui un Tag (o Trasponder) viene letto 
solamente una vola. 
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Identification Cards 

Le Identification Cards non posseggono una alimentazione elettrica propria ma non 
appena si avvicinano al Reader, esse vengono alimentate grazie al campo magnetico 
indotto. Il chip on-board contiene un codice univoco identificativo, che viene inviato non 
appena la Card si avvicina all'unità di lettura. Quindi la stessa unità riceve il codice e lo 
invia ad un microcontrollore, per la sua successiva elaborazione. 



Figura 9: Una Identification Card 


Schema elettrico 

Di seguito viene mostrato lo schema elettrico relativo al RFid Reader. Tutte le componenti 
sono estremamente miniaturizzate, e nei modelli più recenti anche i componenti passivi 
sono in SMD. Occupa un po' di spazio in più l'antenna stampata, per ovvie ragioni. 

Ecco in breve la funzione dei pin del connettore 2x5, il quale permette la connessione ed il 
colloquio con un microcontrollore: 

x OUT: segnale di uscita dall'integrato EM4095 che contiene, tra l'altro, il codice 
univoco della Identification Card; 

^ RDY/CLK: è il piedino che detta il segnale di clock; 

x SHD: se presente un segnale logico basso su questo piedino, RFid Reader entra in 
modalità sleep; 

^ MOD: se presente un segnale logico alto su questo piedino, il segnale di 
modulazione viene emesso dall'antenna e la trasmissione ha luogo. 



Figura 10: Schema elettrico e connessioni RFid Reader 
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Figura 11: RFid Reader completa di cavetto per la connessione 


Esempio 

Di seguito è riportato un esempio di applicazione, creato con mikroBasic. Per eventuali 
modifiche e commenti si rimanda il lettore al sito ufficiale. 

program RFiD 

dim OUT as sbit at RB0_bit 
dim RDY_CLK as sbit at RBl^bit 
dim SHD as sbit at RB2_bit 
dim _MOD as sbit at RB3_bit 

dim OUT_Direction as sbit at TRISBO_bit 
dim RDY_CLK_Direction as sbit at TRISBl_bit 
dim SHD_Direction as sbit at TRISB2_bit 
dim _MOD_Direction as sbit at TRISB3_bit 

dim sync_flag, 
one_seq, 
data^in, 
data^index, 
cnt, 

enti, cnt2 as byte 
i as byte 

_data as byte[256] 
data_valid as byte[64] 

bad_synch as byte 

sub procedure InterruptO 

if ((INTlIFJoit = 1) and (INTlIE_bit = 1)) then 
Ine (cnt) 
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INT1IF bit 


0 


else if ((INTOIF_bit=l) and (INTOIE_bit=l)) then 
cnt = 0 

sync_flag = 1 
INTOlF_bit = 0 
INTOIEJoit = 0 
INTlIFJoit = 0 
INT1IE_bit = 1 
end if 
end if 
end sub 

sub function CRC_Check(dim byref bit_array as byte[64]) as byte 

dim row_count, row_bit, column_count as byte 
row_sum, column_sum as byte 
row_check as byte[5] 
column_check as byte[11] 

row_count = 9 
while row_count < 59 
column_count = 0 
while column_count < 5 

row_check[column_count] = bit_array[row_count+column_count] 
Ine (column_count) 
wend 

row_bit = 0 
row_sum = 0 
while row_bit < 4 

row_sum = row_sum + row_check[row_bit] 

Ine(row_bit) 
wend 

if row_sum.B0 <> row_check[4].BO then 
result = 0 
exit 
end if 

row_count = row_count + 5 
wend 

column_count = 9 
while column_count < 13 
row_bit = 0 
row_count = 0 
while row_bit < 11 

column_check[row_bit] = bìt_array[column_count+row_count] 
Ine(row_bit) 

row_count = row_count + 5 
wend 

row_bit = 0 
column_sum = 0 
while row bit < 10 
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column_sum = column_sum + column_check[row_bit] 
Ine(row_bit) 
wend 

if column_sum.BO <> column_check[10].BO then 
result = 0 
exit 
end if 

Ine (column_count) 
wend 

if bit_array[63] = 1 then 
result = 0 
exit 
end if 

result = 1 

end sub 

'** main program 
ma in : 

ADCON1 = OxOF 
CMCON = 7 

OUT_Direction = 1 
RDY~CLK_Direction = 1 
SHD_Direction = 0 
_MOD_Direction = 0 

SHD = 0 
_MOD = 0 

UARTl_Init(19200) 

Delay_ms(100) 

sync_flag = 0 
one_seq = 0 
data^in = 0 
data^index = 0 
cnt = 0 
enti = 0 
cnt2 = 0 

INTEDGOJoit = 0 
INTEDGlJoit = 1 
INTOIFJoit = 0 
INT1IF_bit = 0 

INTOIEJoit = 0 
INT1IEJoit = 0 
GIE bit = 1 
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while TRUE 

bad_synch = 0 
cnt = 0 
sync_flag = 0 
INT1IFJoit = 0 
INT1IE_bit = 0 
INTOIFJoit = 0 
INTOIEJoit = 1 

while (sync_flag = 0) 
nop 
wend 

while (cnt <> 16) 
nop 
wend 
cnt = 0 

_data[0] = OUT and 1 
data^index = 1 
while data_index <> 0 
while (cnt <> 32) 
nop 
wend 
cnt = 0 

_data[data_index] = OUT and 1 
if (data_index and 1) then 

if (_data[data_index] xor _data[data_index-l]) 
bad_synch = 1 
break 
end if 
end if 

Ine(data_index) 
wend 

INT1IEJoit = 0 

if (bad_synch) then 
continue 
end if 
enti = 0 
one_seq = 0 
for enti = 0 to 127 

if (_data[cntl << 1] = 1) then 
Ine(one_seq) 
else 

one_seq = 0 
end if 

if (one_seq = 9) then 
break 
end if 
next enti 

if (one_seq = 9) and (enti < 73) then 
data valid[0] = 1 


= 0 then 
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data[enti << 1] 


data_valid[1] = 1 
data_valid[2] = 1 
data_valid[3] = 1 
data_valid[4] = 1 
data_valid[5] = 1 
data_valid[6] = 1 
data_valid[7] = 1 
data_valid[8] = 1 
for cnt2 = 9 to 63 
Ine (enti) 

data_valid[cnt2] = 
next cnt2 
if (CRCjCheck(data_valid) = 1) then 
UARTlJAJriteJText ("CRC CHECK OKI") 
UARTl_Write(13) 

UARTljAlrite (10) 
for i = 0 to 64 

if data_valid[i] = 0 then 
UARTljAlrite ("0") 
else 

UARTl_Write("1") 
end if 
next ì 

UARTljAlrite(13) 

UARTljAlrite (10) 

Delayjns (500) 
end if 
end if 


wend 
end. 


Conclusioni 

Come si è visto, implementare un sistema di controllo è abbastanza semplice. Il 
microcontrollore si occupa di tutte le operazioni derivanti dal riconoscimento o meno della 
IC, con abbassamento di costi e di tempo di sviluppo. 
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Gestire le uscite di un PIC 


Ecco come scrivere in C degli algoritmi dedicati alla gestione delle uscite dei PIC, per 
comandare LED, display ed altri dispositivi, utilizzando le tecniche più efficienti utilizzando 
il compilatore MikroC. 

Di seguito è mostrato il codice per fare lampeggiare un LED collegato alla porta RBO del 
PIC. Per comodità riportiamo in figura 1 anche lo schema elettrico del circuito: 

void main() { 

PORTB = 0; 

TRISB = 0; 
while(1) { 

PORTB = PORTB A 0b00000001; 

Delay_ms(500); 

} 

} 

Il programma è molto semplice: utilizza solamente un’operazione di XOR (l’operatore “ A ” 
del C) per ottenere l’inversione del primo bit della porta B (e quindi il lampeggio del LED), 
ed una routine di ritardo per determinarne la frequenza. Se dovessimo generare delle 
combinazioni più complesse (come avviene in molte applicazioni reali) questo approccio 
potrebbe non essere adeguato. Esistono diverse possibilità che è il caso di considerare, 
dal momento che ciascuna di esse può adattarsi meglio a specifiche applicazioni. 
Supponiamo ad esempio di utilizzare 8 LED, ciascuno collegato ad un piedino della porta 
B come mostrato in figura 2, e di volerli accendere in sequenza nelle due direzioni (il 
classico effetto “supercar”). Le alternative più convenienti sono due: in un caso possiamo 
utilizzare gli operatori del C che permettono di manipolare i bit, nell’altro possiamo 
utilizzare una tabella di consultazione (look-up table). Consideriamo il primo caso, cioè 
partiamo da una configurazione delle uscite, ed otteniamo le altre operando sui bit. Il 
codice è il seguente: 

void main() { 
char dir; 

/* Direzione di scorrimento 
1=sinistra, 0=destra V 
dir-1; 

// Inizializz. porta B 
PORTB = 0x01; 

TRISB = 0; 

// Loop infinito 
while(l) { 

// Raggiunti bordi? 
if (PORTB&OxOI) dir=1; 
if (PORTB&0x80) dir=0; 

//Aggiornamento direzione 
if (dir) { 

PORTB = PORTB « 1; 

} else { 

PORTB = PORTB » 1; 
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} 

Delay_ms(100); 

} 

} 

Il funzionamento del programma dovrebbe risultare abbastanza intuitivo: inizialmente 
viene dichiarata una variabile (dir) per tenere traccia della direzione di scorrimento, in 
seguito vengono inizializzate le variabili e le porte, e poi viene eseguito il loop principale. 
Durante il funzionamento la variabile dir assumerà soltanto due valori (scelti da noi), quindi 
è conveniente dichiararla del tipo più piccolo possibile gestito dal C, cioè char (8 bit). Le 
linee della porta B sono state configurate tutte come uscite (TRISB=0), e soltanto il primo 
piedino è stato posto alto (PORTB=0x01 ). Ricordiamo che il MikroC permette di esprimere 
i valori numerici anche in binario (anteponendo “Ob” al numero), ma abbiamo preferito 
utilizzare la notazione esadecimale per rendere il codice maggiormente portabile. Per 
convertire questi valori in binario si può utilizzare il convertitore Qconvertor, che si trova in 
basso nella finestra del messaggi del MikroC. All’interno del loop principale viene 
dapprima verificato se il LED attualmente acceso è il primo o l’ultimo, e in ciascuno di 
questi due casi viene cambiata la direzione dello scorrimento. Per eseguire questo 
controllo è stata utilizzata l’istruzione if del C: solo se la condizione dentro le parentesi è 
verificata l’espressione che segue vene eseguita. L’espressione che viene controllata è 
l’AND binario tra i bit della porta B e 0x01 (oppure 0x08). Questa espressione darà 0x01 
solo se il bit meno significativo della porta B sarà alto (lo stesso per il più significativo nel 
caso di 0x80), altrimenti zero. Per maggiore chiarezza avremmo potuto scrivere: 

if((PORTB&0x01)==0x01) dir=1; 
if ((PORTB&0x80)==0x80) dir=0; 

ma ricordiamo che il C considera vera qualsiasi espressione che non valga 0, quindi 
anche non indicando il valore atteso otteniamo lo stesso risultato. Abbiamo usato lo stesso 
accorgimento per il frammento di codice successivo, che è quello che si occupa 
deH’aggiomamento della posizione. Se la variabile dir vale 1 viene eseguito uno 
scorrimento binario di una posizione a sinistra (a destra neN’immagine), altrimenti (else) 
viene eseguito uno scorrimento a destra (a sinistra neN’immagine). Gli scorrimenti 
(operatori “«” e “»” del C) produrranno la sequenza di valori: 0x01, 0x02, 0x04, 0x08, 
0x10..., 0x80, e poi a ritroso (quando cambierà la direzione di scorrimento) fino a 0x01. 
Dopo ogni scorrimento attendiamo lOOms usando l’apposita routine di libreria Delay_ms, 
messa a disposizione dal MikroC, e ripetiamo l’intera routine, all’infinito. Consideriamo 
adesso un altro approccio per ottenere lo stesso risultato. In questo caso utilizzeremo una 
look-up table per memorizzare le configurazioni delle uscite che vogliamo ottenere. Il 
codice è il seguente: 

void mairi () { 
char n=0; 

char Ieds[14]={0x01, 0x02, 

0x04, 0x08, 0x10, 0x20, 

0x40, 0x80, 0x40, 0x20, 

0x10, 0x08, 0x04, 0x02}; 

// Inizializz. porta B 
TRISB = 0; 

// Loop infinito 
while(l) { 

PORTB=leds[n]; 
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n++; 

if (n==14) n=0; 

Delay_ms(100); 

} 

} 

Per creare la tabella di consultazione abbiamo utilizzato un array ( leds[...]), in cui abbiamo 
inserito manualmente le configurazioni delle uscite volute (che sono le stesse che 
abbiamo ottenuto col programma precedente). Ci occorrono soltanto 14 voci per la tabella, 
che sono state inizializzate direttamente nella dichiarazione dell’array. Inoltre abbiamo 
dichiarato un’altra variabile (n) che verrà utilizzata come contatore, cioè come indice per 
scorrere la tabella. Nel loop principale assegniamo direttamente il valore corrente della 
tabella alla porta B, inoltre incrementiamo l’indice n (con l’istruzione n++). Quando l’indice 
raggiungerà il valore 14, sarà riportato a 0, e quindi il conteggio ripartirà da questo valore. 
Notare la differenza tra “==” ed “=” nell’istruzione if. Ricordiamo che il primo è un 
operatore relazionale, che controlla se il valore dell’espressione di sinistra è uguale a 
quello dell’espressione di destra (restituendo un valore di verità). L’altro operatore invece 
assegna un valore ad una variabile. Questa seconda versione del programma, sebbene 
richieda un po’ più di memoria, ha un vantaggio importante: basta cambiare i valori in 
tabella per ottenere comportamenti diversi. Si provi ad esempio ad utilizzare questi valori: 

char Ieds[14]={0x81, 0x42, 

0x24, 0x18, 0x18, 0x24, 

0x42, 0x81, 0x42, 0x24, 

0x18, 0x18, 0x24, 0x42}; 

Ci saranno due LED accesi che si muoveranno in direzione opposta (basta convertire in 
binario i valori per rendersene conto). L’approccio usato nel primo programma invece 
risulta più flessibile quando le configurazioni utilizzate non sono sempre le stesse, ma 
variano nel tempo, magari in base a condizioni esterne. 


PILOTARE I DISPLAY A 7 SEGMENTI 

I display a 7 segmenti rappresentano un economico e funzionale dispositivo di 
visualizzazione. Vedremo quindi in questo paragrafo come utilizzarli. Un display a 7 
segmenti è composto da 

8 LED disposti a formare 7 segmenti più un punto decimale (non sempre presente), con 
cui è possibile rappresentare numeri, lettere e simboli grafici. I display a 7 segmenti sono 
disponibili in due versioni, che differiscono per i collegamenti dei LED: in entrambi i casi i 
LED possono essere pilotati indipendentemente da un terminale, mentre l’altro è comune 
a tutti. Il terminale comune può essere l’anodo o il catodo dei LED (e da questo particolare 
deriva il nome del display). Quando il terminale comune è il catodo (figura 3), quest’ultimo 
sarà collegato a massa, e per accendere un segmento sarà sufficiente fornire 
un’alimentazione positiva al rispettivo anodo (ad esempio utilizzando un piedino di uscita 
portato a livello logico alto). Nel caso di display ad anodo comune (figura 4), questo 
terminale verrà collegato al positivo dell’alimentazione, e per accendere un segmento sarà 
necessario portare a massa il catodo del segmento che si vuole accendere (usando un 
piedino di uscita a livello logico basso). Per pilotare un display a 7 segmenti avremo 
bisogno quindi di almeno 8 uscite del PIC, e con queste potremo gestire soltanto un 
carattere. Per fare le prime prove colleghiamo il display al PIC come mostrato in figura 5 
(stiamo quindi utilizzando un display a catodo comune): i segmenti verranno pilotati tramite 
i piedini della porta B. Possiamo quindi procedere come negli esempi visti fino ad ora, 


Fare Elettronica n.347 - Settembre 2014 p.57 


l’unico problema è che dobbiamo ricavare per ogni carattere che vogliamo visualizzare il 
corrispondente valore da inviare alla porta B (che esprime quali segmenti sono accesi e 
quali spenti). Per fare questo possiamo utilizzare l’apposito strumento messo a 
disposizione dal MikroC, richiamabile selezionando la voce Severi Segment Convertor 
dal menu Tools (figura 6). È sufficiente disegnare il carattere che vogliamo visualizzare 
per avere il valore numerico corrispondente ad uno dei due tipi di display. Nel nostro caso 
ricaveremo il valore per le cifre da 0 a 9 e per le lettere da A, b, c, d, E ed F (che ci 
potrebbero servire per rappresentare valori esadecimali). Un modo molto semplice per 
associare questi caratteri ai valori numerici consiste nell’utilizzare un array. Vediamo quindi 
come realizzare un programma che conta continuamente da 0 a 9: 

void main() { 
char n=0; 

char segs[16]={0x3F, 0x06, 

0x5B, 0x4F, 0x66, 0x6D, 

0x7D, 0x07, 0x7F, 0x6F, 

0x77, 0x7C, 0x39, 0x5E, 

0x79, 0x71}; 

// Inizializz. porta B 
TRISB = 0; 

// Loop infinito 
while(l) { 

PORTB=segs[n]; 

n++; 

if(n==lO)n=0; 

Delay_ms(1000); 

} 

} 

Come si può notare il programma è quasi identico a quello visto precedentemente, sono 
stati modificati soltanto i valori contenuti nell’array, che in questo caso codificano i caratteri 
voluti. Se si estende il conteggio fino a 16 sarà possibile visualizzare anche le cifre 
esadecimali da A a F. Non possiamo superare 16 perché altrimenti leggeremmo una 
posizione dell’array che non esiste, ottenendo un risultato imprevedibile. E se volessimo 
utilizzare più cifre, e quindi più unità a 7 segmenti? Occorrerebbe utilizzare molte più porte 
di I/O, oppure ricorrere alla tecnica del multiplexing, molto utilizzata in questi casi. Occorre 
collegare i display come mostrato in figura 7 ed utilizzare soltanto 4 linee di I/O aggiuntive 
(questa volta provenienti dalla porta A) per gestire le 4 cifre. Il funzionamento è semplice: 
le linee della porta B saranno condivise da tutti i display, che quindi riceveranno gli stessi 
dati, ma soltanto un display alla volta sarà acceso, comandando attraverso la porta A i 
transistor BJT sui cui collettori si trovano i display. In questo modo riusciamo a comandare 
individualmente i singoli display: se vogliamo visualizzare un carattere sul display più a 
sinistra, dovremo inviare il codice del carattere sulla porta B e portare alto soltanto RAO. 
Ovviamente soltanto un display alla volta potrà essere acceso. Occorre quindi accenderli 
in successione ad una velocità tale da non farne percepire all’occhio lo spegnimento. Per 
ottenere questo effetto è sufficiente accendere ogni cifra almeno ogni 20ms. Dal momento 
che le cifre sono 4, dovremo tenerle accese singolarmente meno di 5ms. Per evitare un 
effetto di “sfarfallamento” possiamo anche usare una velocità maggiore (senza esagerare, 
altrimenti otterremo una bassa luminosità). 

Riassumendo: 

• Sulla porta B dovranno essere inviati ciclicamente i valori corrispondenti alle 4 cifre che 
vogliamo visualizzare. 
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• Sulle porta A dovrà essere portata alta una sola linea alla volta, quella corrispondente alla 
cifra da visualizzare (avremo quindi ciclicamente ObOOOl, ObOOIO, ObOlOO, Obi000). Il 
codice che implementa questo comportamento è il seguente: 

void main() { 
char n, ds; 

char segs[ 16]={0x3F, 0x06, 

0x5B, 0x4F, 0x66, 0x6D, 

0x7D, 0x07, 0x7F, 0x6F, 

0x77, 0x7C, 0x39, 0x5E, 

0x79, 0x71}; 

char cifra[4]={1,2,3,4}; 

// Inizializz. porte 
TRISA = 0; 

TRISB = 0; 

// Loop infinito 
while(l) { 
ds = 1; 

for(n=0; n<4; n++) { 

PORTB = segs[cifra[n]]; 

PORTA = ds; 

Delay_ms(2); 
ds = ds « 1; 

} 

} 

} 

Il codice somiglia molto a quello visto in precedenza, le uniche differenze riguardano 
l’utilizzo di un altro array ( cifra[...]), che contiene le cifre da visualizzare nei 4 display, e 
l’impiego della porta A per selezionare il display. Il loop principale contiene un ciclo for, che 
viene ripetuto per 4 volte (una per ogni cifra), al cui interno viene impostato il valore della 
cifra corrente sulla porta B, ed aggiornato il contenuto della porta A. In pratica all’inizio la 
porta A conterrà il valore ObOOOl, alla porta B viene assegnato il valore adatto a 
rappresentare la prima cifra, si attende 2ms, al valore della porta A viene applicato uno 
scorrimento a sinistra di un bit, ottenendo ObOOIO, ed il ciclo for riprende con la seconda 
iterazione, in cui viene assegnato alla porta B il codice per la seconda cifra. Si prosegue 
così fino alla quarta, e quindi si esce dal ciclo for, ma non dal loop principale, che si 
ripeterà all’infinito. Sul display dovrebbero apparire le cifre 1234 indicate nell’array cifra. A 
questo punto potremo pensare di sfruttare il display realizzato per implementare delle 
funzioni utili. Se ad esempio riuscissimo a visualizzare il valore di una qualsiasi variabile, 
potremmo usare il display come un comodo dispositivo di output (sia nelle applicazioni, sia 
in fase di debug). Per fare questo possiamo utilizzare alcune funzioni messe a 
disposizione dalle librerie del MikroC, ed in particolare quelle che permettono di creare 
delle stringhe a partire dal valore numerico di una variabile. Una di queste funzioni è la 
seguente: 

void ShortToStr(short number, 
char *output); 

La funzione prende in ingresso una variabile di tipo short, ed un puntatore ad un array di 4 
caratteri (come il nostro cifra}...]), e restituisce nell’array di caratteri una stringa 
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corrispondente al numero indicato come primo parametro. Ad esempio: 


short t = -24; 
char txt[4]; 

ShortToStr(t, txt); 

In questo caso l’array txt[...] conterrà i seguenti 4 caratteri “ -24” (il primo carattere è uno 
spazio). Esistono anche le funzioni IntToStr, WordToStr, FloatToStr, che lavorano nello 
stesso modo, ma usano tipi di variabili diversi e restituiscono un numero maggiore di 
caratteri. Possiamo utilizzare questa funzione con il codice fino ad ora scritto? Si, ma 
dobbiamo apportare qualche piccola modifica. La funzione infatti restituisce una stringa, i 
cui valori sono codificati in ASCII. Se diamo un’occhiata alla tabella dei codici ASCII (menu 
Tools/ASCII Chart) vediamo che i codici che ci vengono restituiti vanno dal 48 al 57 
(decimale) per i caratteri numerici, ma comprendono anche il 32 dello spazio, ed il 45 del 
segno Se escludiamo i due segni non numerici, i codici dei caratteri numerici possono 
essere ottenuti semplicemente sottraendo 48 al codice ASCII (o anche considerando solo i 
4 bit meno significativi, cioè eseguendo un AND con OxOF). Il codice diventa quindi il 
seguente: 

void main() { 

char n, ds, vai; 

char segs[16]={0x3F, 0x06, 

0x5B, 0x4F, 0x66, 0x6D, 

0x7D, 0x07, 0x7F, 0x6F, 

0x77, 0x7C, 0x39, 0x5E, 

0x79, 0x71}; 
char cifra[4]; 
val=-47; 

// Inizializz. porte 
TRISA = 0; 

TRISB = 0; 

// Conversione 
ShortToStr(val, cifra); 

// Loop infinito 
while(l) { 
ds = 1; 

for(n=0; n<4; n++) { 

PORTB=segs[cifra[n]-48]; 
if (cifra[n]==32)PORTB=OxOO; 
if (cifra[n]==45)PORTB=0x40; 

PORTA = ds; 

Delay_ms(2); 
ds = ds « 1; 

} 

} 

} 

In pratica è stata aggiunta soltanto la variabile var, la chiamata alla funzione ShortToStr, ed 
alcuni controlli nel loop che visualizza i dati. In particolare all’inizio è visualizzata la cifra 
(ottenuta dal codice ASCII meno 48), poi viene verificato se il carattere è uno spazio o un 
segno meno, ed in questi casi viene corretto l’output sulla porta B con i caratteri 
corrispondenti (tutti i segmenti spenti nel caso dello spazio, o solo quello centrale acceso 
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nel caso del meno). Poi viene assegnato il valore appropriato alla porta A, come accadeva 
nell’esempio precedente. A questo punto possiamo visualizzare il contenuto di qualsiasi 
variabile del nostro programma. Un’ultima nota interessante: non abbiamo mai utilizzato il 
punto decimale presente nei display. Se lo volessimo accendere in una qualsiasi delle 
quattro cifre, sarebbe sufficiente attivare il bit più significativo della porta B. Questo può 
essere ottenuto eseguendo un OR (operatore “|” del C) tra il codice del carattere 
attualmente visualizzato ed il valore binario Obi 0000000 (cioè 0x80 esadecimale): 

if (punto) PORTB=PORTB|0x80; 

TIMER ED INTERRUZIONI 

Il precedente esempio ha mostrato come sia possibile utilizzare un display a 7 segmenti 
per visualizzare il contenuto di una variabile. Come abbiamo visto per ottenere una buona 
visualizzazione delle 4 cifre è necessario rispettare delle precise temporizzazioni. Risulta 
quindi piuttosto difficile aggiungere altre funzioni al programma visto prima, perché 
qualsiasi altro compito inserito nel loop principale altererebbe le temporizzazioni del 
display, e risulterebbe a sua volta rallentato dai tempi di attesa utilizzati per il display. Per 
risolvere questo problema è necessario separare e rendere indipendenti le 
temporizzazioni e le funzioni di gestione del display dalla normale esecuzione del 
programma: questo può essere ottenuto utilizzando il timer del PIC e le interruzioni. Il 
meccanismo è molto semplice: il PIC ha un timer ad 8 bit (chiamato TimerO o TMR0) che 
conta da 0 ad OxFF (in totale 256 valori), ed è incrementato ad ogni ciclo macchina (4 cicli 
di clock) o suoi multipli. Quando il valore del timer supera OxFF, può essere generata 
un’interruzione. Utilizzando il timer è quindi possibile richiamare un’apposita funzione (la 
routine d’interruzione) a intervalli di tempo prestabiliti. Nel nostro caso il codice aN’interno 
della routine dovrà aggiornare il display un digit alla volta. Occorrerà quindi impostare il 
timer ed il suo prescaler in modo da generare un interrupt ogni 2ms. Per abilitare le 
interruzioni associate al TMR0 dobbiamo impostare ad 1 i bit GIE e T0IE del registro 
INTCON, ed abilitare il prescaler col fattore di divisione voluto sul registro OPTION_REG. 
Se abbiamo una frequenza di clock di 4MHz, possiamo ottenere un’interruzione ogni 2ms 
usando un fattore di divisione pari a 8 (infatti 4*256*8/4MHz=2ms). Dopo avere impostato 
il corretto valore nei registri, dobbiamo scrivere la routine di gestione delle interruzioni. Per 
fare questo sarà sufficiente creare una funzione chiamata “interrupt”, il MikroC la 
riconoscerà come routine di gestione delle interruzioni, e la richiamerà automaticamente in 
caso di interruzioni. Il codice risultante è il seguente: 

char n, ds, cifra[4]; 
char segs[ 16]={0x3F, 0x06, 

0x5B, 0x4F, 0x66, 0x6D, 

0x7D, 0x07, 0x7F, 0x6F, 

0x77, 0x7C, 0x39, 0x5E, 

0x79, 0x71}; 
void mairi () { 
short vai; 

// Inizializz. porte 
TRISA = 0; 

TRISB = 0; 
n=0; 
ds=1; 
val=-125; 

ShortToStr(val, cifra); 

OPT!ON_REG = 0x82; 
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TMRO = 0; 

INTCON = OxAO; 
while(l) { 

} 

} 

void interrupt() 

{ 

PORTA=ds; 

PORTB=segs[cifra[n]-48]; 
if (cifra[n] == 32) PORTB=OxOO; 
if (cifra[n]==45) PORTB=0x40; 
n++; 

ds «= 1; 
if (n > 3) { 
n = 0; 
ds = 1; 

} 

// Reset del timer 
TMRO = 0; 

//Reset flag TMROIF/TMROIE 
INTCON = 0x20; 

} 

Le differenze rispetto alla versione precedente sono essenzialmente 3. Innanzi tutto 
alcune delle variabili utilizzate prima sono state dichiarate fuori dalla funzione mairi, quindi 
risultano essere delle variabili globali: tutte le funzioni possono leggerle e modificarle. 
Questo risulta utile dal momento che devono essere inizializzate o modificate aN’interno 
della funzione mairi, ma devono essere lette ed utilizzate dentro la routine d’interruzione, 
inoltre il loro valore deve essere mantenuto anche quando si esce dalle rispettive funzioni. 
In questo modo aN’intemo del loop principale si potrà assegnare un valore all’array cifra, e 
la routine d’interruzione provvederà a visualizzarlo indipendentemente. La funzione main è 
quasi vuota: contiene solamente le istruzioni di inizializzazione dei registri e delle variabili, 
e finisce con un loop infinito vuoto, che in pratica attende solamente il verificarsi delle 
interruzioni. La routine d’interruzione invece svolge le stesse funzioni viste prima, solo che 
opera su una cifra alla volta: aggiorna il valore di PORTA e PORTB come nel programma 
precedente, modifica il valore di n e ds in modo da puntare al prossimo carattere, e prima 
di terminare resetta il valore del timer e del suo flag d’interruzione. Non è necessario 
utilizzare la funzione di ritardo dal momento che i valori impostati sulle porte saranno 
mantenuti fino alla prossima interruzione, che si verificherà dopo circa 2ms. A questo 
punto sarà possibile eseguire altre operazioni nel loop principale e modificare come si 
vuole l’array cifra[], ed il display sarà aggiornato di conseguenza ed in maniera 
automatica. Ad esempio si può realizzare un conteggio inserendo nel loop il seguente 
codice: 

while(l) { 

ShortToStr(val, cifra); 

Delay_ms(250); 

val++; 

} 

Notare che in questo caso il ritardo di 250ms inserito non influisce completamente 
suH’aggiornamento del display, che continua a funzionare con le sue temporizzazioni! 
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luminotronica 2014 si fa in tre 


L’evento professionale italiano dedicato a lighting, elettronica e building automation 



Tante le novità di llluminotronica 2014, l’unica mostra-convegno italiana sul mondo delle 
nuove tecnologie per l'illuminazione a LED e la domotica in programma a Padova dal 9 
all'l 1 ottobre. Un appuntamento che si preannuncia ricco di contenuti, corsi, convegni e 
iniziative speciali dedicati a un pubblico specializzato di professionisti. Un momento, 
inoltre, per formarsi e informarsi, per aggiornarsi e confrontarsi, per incontrare e contattare 
gli esperti del mercato. 

Le aree espositive di llluminotronica 

Tra le novità di quest’anno, la divisione della mostra-convegno in tre grandi aree 
espositive, per offrire una visione completa sui settori dell’elettronica, dell’illuminazione e 
della building automation, tre ambiti sempre più interconnessi e integrati tra loro. 

1. Illuminazione a LED ed elettronica per il lighting 

È l’area storica e più importante di llluminotronica che vede la partecipazione sia di 
produttori di corpi illuminanti (indoor e outdoor) sia di aziende che producono e forniscono 
componenti e sottosistemi per il lighting (LED/OLED, ottiche, driver, connettori, 
alimentatori, dissipatori ma anche sensori, tecnologie wireless eco.). 

2. Domotica e Building Automation 

Un’area nuova, molto vicina al mondo della luce, dove vedere e toccare con mano le 
soluzioni più innovative per il controllo e la gestione “intelligente” dell’edificio. 

3. Elettronica Micro 

Il rinnovato punto di incontro per chi opera nell’elettronica industriale, per chi progetta e 
produce in Italia componenti, attrezzature e sistemi. Un’area promossa da Assodel per 
valorizzare la pervasività dell’elettronica nel rapporto con la crescente esigenza di 
efficienza energetica. 

Iniziative speciali 

Tra le iniziative speciali, un Laboratorio per gli installatori, con prove tecniche e 
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dimostrazioni sull’utilizzo e sul controllo dei LED, sulle tecnologie per il lighting e la 
domotica. Un’area demo dove ricreare gli effetti benefici della luce a LED e della domotica 
in spazi da interno (gli ambienti di una casa/albergo) e in una strada e dove toccare con 
mano le soluzioni più innovative. Un angolo (Codega Corner), inoltre, dove incontrare gli 
esperti del settore e confrontarsi con le loro esperienze e idee. 

Ma anche premi - come il Premio Codega alle eccellenze nel lighting designer e il LEDin Award ai giovani designer 
e alle idee più innovative nella progettazione di corpi illuminanti - corsi di formazione di vario livello tecnico, talk 
show, convegni e momenti conviviali. 


Per maggiori informazioni: 
www.illuminotronica.it 
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Linear Technology Corporation presenta l'LT3062, un regolatore di tensione lineare ad alta 
tensione, basso rumore e basso dropout. Il circuito integrato fornisce fino a 200mA di 
corrente di uscita continua con una tensione di dropout di 300mV a pieno carico. L'LT3062 
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presenta un ampio range di tensioni di ingresso compreso tra 1,6V e 45V, per fornire 
tensioni di uscita regolabili comprese tra 0,6V e 40V. Un unico condensatore garantisce un 
funzionamento programmabile a bassissimo rumore - solo 30pVRMS su una larghezza di 
banda di lOHz-IOOkHz - e funzionalità di "soft start" del riferimento, al fine di impedire 
l'overshoot della tensione di uscita all'accensione. Il valore di tolleranza della tensione di 
uscita deiri_T3062 è altamente preciso e corrisponde al ±2% rispetto a linea, carico e 
temperatura. L'ampio range di tensioni di ingresso e di uscita del dispositivo, la rapida 
risposta al transitorio, la bassa corrente di riposo di soli 40pA (in modalità operativa) e 
<1pA (in modalità di arresto) rendono l'LT3062 il dispositivo ideale per sistemi portatili 
alimentati a batteria che richiedono una durata ottimale e per l'uso nelle applicazioni di 
alimentazione dei settori automotive, industriale e avionico. il dispositivo funziona con 
condensatori ceramici di uscita di dimensioni ridotte e a basso costo che ottimizzano la 
stabilità e la risposta al transiente. È stabile con un condensatore di uscita minimo da 
3,3pF. I condensatori esterni di dimensioni ridotte possono essere utilizzati senza ulteriori 
resistenze in serie (ESR), requisito spesso necessario di molti altri regolatori. Il dispositivo 
è anche dotato di un circuito interno che offre protezione in caso di inversione della 
polarità della batteria, dell'uscita e della corrente, limitazione della corrente con foldback in 
base a un valore predefinito e limitazione della temperatura. L'LT3062 viene offerto in 
package DFN e MSOP di 2 x 3mm e a 8 conduttori per un ingombro ridotto. Le versioni di 
grado E e I hanno una temperatura di giunzione tra -40°C e +125°C, la versione di grado 
H (elevata disponibilità) è specificata per il range di temperature compreso tra -40°C e 
+ 150°C, mentre la versione MP (militare) funziona nel range da -55°C a +150°C. Il prezzo 
per 1.000 pezzi parte da $1,70/cad. per la versione E nei package DFN e MSOP. Tutte le 
versioni sono disponibili a magazzino. 

Per maggiori informazioni, visitare la pagina www.linear.com/product/LT3062 


Toshiba presenta lo starter kit TZ5000 
App Lite 

Toshiba Electronics Europe annuncia un tool online che aiuta i progettisti ad analizzare le 
prestazioni dei componenti utilizzati negli stadi di potenza dei circuiti embedded e a 
migliorare l'efficacia e l'efficienza generali di un sistema elettronico. Il Toshiba 
Semiconductor Web Simulator permette agli utenti di simulare le prestazioni dei MOSFET in 
diverse condizioni di tensioni e temperatura, nonché di analizzare le forme d’onda relative 
alla commutazione in convertitori AC/DC e DC/DC di diverse topologie, tra cui full-bridge, 
flyback e conversione buck sincrona. Oltre ai MOSFET, è possibile analizzare il 
comportamento di regolatori a bassa caduta di tensione (LDO, Low Drop-Out) e gli 
interruttori di carico integrati. Essendo basati su cloud, i dati e i progetti possono essere 
condivisi facilmente tra i team di progettazione, a prescindere da dove essi si trovino. 
Inoltre, il simulatore può essere scaricato e utilizzato in modalità off-line, permettendo una 
progettazione circuitale ancora più versatile. 

Il tool si compone di tre elementi interattivi: datasheet, application designer e design note. I 
primi due elementi riguardano i MOSFET, gli altri i regolatori LDO e gli interruttori di carico. 
Con il datasheet di MOSFET interattivo, il progettista può scegliere i componenti da una 
lista e analizzare la scelta effettuata utilizzando un tracciatore di curve personalizzabile e 
circuiti di prova per le caratteristiche dinamiche. Per semplificare la scelta, la ricerca può 
essere raffinata regolando parametri come tipo di contenitore, resistenza e gamma di 
tensioni. 
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Utilizzando il designer applicativo interattivo è possibile scegliere un dispositivo MOSFET 
da utilizzare in diverse configurazioni topologiche, sulla base di specifici requisiti di 
progetto. È quindi possibile valutare le prestazioni del componente nel sistema utilizzando 
i tool di analisi e di simulazione disponibili online. Al termine della simulazione e dei 
confronti, viene generato un rapporto riepilogativo che comprende uno schema circuitale e 
una lista di materiali. Questo documento può essere stampato, salvato e condiviso con 
altri colleghi. È anche possibile esportare i modelli di progetto dei MOSFET in altri ambienti 
di simulazione. 

La nota di progetto interattiva offre funzioni simili per i regolatori LDO e i commutatori sotto 
carico integrati. Gli utenti possono identificare i componenti in base ai parametri scelti, 
creare un progetto circuitale con un solo clic, analizzarlo e generare una lista di materiali 
con un rapporto riepilogativo. 

Per registrarsi e iniziare a utilizzare il Toshiba Semiconductor Web Simulator, fare clic qui 
oppure collegarsi alla pagina 

http://www.semicon.toshiba.co.ip/enq/desiqn support/simulation/index.html 
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Nuovo nato in casa Microchip 

Microchip annuncia un nuovo ingresso nella sua fa Famiglia di microcontroller 
PICI 2/16LF155X 8-bit (MCU), i dispositivi PIC16LF1554 e PIC16LF1559 
(PICI 6LF1554/9). Il PICI 6LF1554/9 contiene due Analogue-to-Digital Converter (ADC) 
indipendenti con campionature da 100K al secondo 10-bit, con supporto per Capacitive 
Voltage Divider (CVD) hardware per rilevamento tattile capacitivo. Questa eccezionale 
configurazione ADC permette una maggiore efficienza di acquisizione da parte di sensori 
ed è grandemente di sostegno con tecniche avanzate di touch-sensing in ambienti 
fortemente rumorosi, applicazioni low-power, tastiere a matrice e progetti di applicazioni 
resistenti all'acqua. 



L'MCU PIC16LF1554/9 14- e 20-pin combina fino a 17 canali ADC con moduli CVD 
automatici per implementare rilevamento capacitivo e altre applicazioni di campionamento 
front-end con sovraccarico software minimale. In particolare, il CVD hardware riduce il 
codice per implementazioni di rilevamento tattile capacitivo di oltre il 40%. I dispositivi 
includono anche Flash fino a 14 KB / RAM 512 Byte, un oscillatore interno a 32 MHz e due 
moduli PWM, oltre a l 2 C™, SPI e EUSART per le comunicazioni. Inoltre sono conformi a 
eXtreme Low Power (XLP) con correnti active e sleep rispettivamente di 35 pA/MHz e 30 
nA, per applicazioni dove la conservazione dell'energia è essenziale. Queste 
caratteristiche combinate con il basso prezzo ed il piccolo footprint dei PICI 6LF1554/9, li 
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rende adatti per una vasta gamma di applicazioni nell'elettronica di consumo, come 
telecomandi, riproduttori audio, e accessori per cellulari, piccoli elettrodomestici, dispositivi 
indossabili tra cui cuffie, orologi, e bracciali da fitness; in applicazioni medicali come 
monitor di pressione sanguigna e battito cardiaco indossabili; nel settore automotive per 
controlli e rilevamenti di bordo e pannelli di controllo; e nel settore industriale in 
applicazioni di RFID e sensori; oltre a molte altre applicazioni. 

La completa suite Microchip di strumenti di sviluppo supporta gli MCU PICI6LF1554/9, ivi 
compreso anche \'MPLAB® X Integrateci Development Environment (IDE); PICkit™ 3 
(PG164130) offerto al un prezzo di 44,95$; MPLAB XC8 Compiler per MCU PIC 8-bit e 
MPLAB® Code Configurator. 

Gli MCU PICI 6LF1554 sono disponibili da subito sia in campionature che in quantità per 
volumi di produzione nei package 14-pin PDIP, TSSOP, SOIC e 16-pin QFN (4 x 4 x .9 
mm). Gli MCU PIC16LF1559 sono disponibili da subito sia in campionature che in quantità 
per volumi di produzione nei package 20-pin PDIP, SSOP e QFN (4 x 4 x .9 mm). 

Maggiori informazioni su: http://www.microchip.com/qet/08KC 
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Proteggere gli Investimenti in R&D 
con l’Autenticazione Sicura 


di Scott Jones - Executive Director, Embedded Security, Maxim Integrated 

Le soluzioni di autenticazione sicura offerte da Maxim consentono agli sviluppatori di proteggere i loro 
sistemi dagli inevitabili tentativi di contraffazione che prendono di mira accessori e sottosistemi. La 
disponibilità di una memoria utente a prova di manomissione, inoltre, fornisce metodi sicuri per abilitare o 
disabilitare le funzioni dei sistemi con funzionalità configurabile. In guesto articolo vedremo come un piccolo 
ma potente pezzetto di silicio possa fare una grande differenza nel bilancio economico d’impresa. 


Introduzione 

Nell’era dei furti di identità e degli identificativi fasulli, è estremamente importante poter contare su 
identificazioni certe. Questo vale non solo per le persone, ma anche per i prodotti elettronici di ogni tipo o 
quasi. I fabbricanti, infatti, hanno la necessità di proteggere i loro prodotti dai componenti contraffatti che le 
aziende produttrici di accessori e ricambi (aftermarket) tentano di introdurre nella loro catena di fornitura 
OEM. 



Figura 1. Modello di calcolo del MAC. 

L’autenticazione sicura costituisce un’efficace soluzione di tipo elettronico per affrontare questa minaccia, e 
permette inoltre di aggiungere funzioni utili al prodotto finito. Questo articolo illustra il concetto 
dell’autenticazione e in particolare la soluzione messa a punto da Maxim - con i componenti definiti 
“autenticatori sicuri” - per soddisfare una gamma di requisiti applicativi comprendente la protezione della 
proprietà intellettuale, la gestione delle licenze HW/SW embedded, l’impostazione sicura delle soft-feature e 
dello stato, la conservazione dei dati a prova di manomissione. 

Cos’è l’autenticazione? 

L’autenticazione è un processo finalizzato a fornire la prova dell’identità nella relazione tra due o più entità. 
Nel caso di autenticazione unidirezionale, una sola entità fornisce prova della propria identità ad un’altra. 
Nell’autenticazione bidirezionale, la prova dell’identità viene fornita reciprocamente da ciascuna entità 
all’altra. Il metodo di autenticazione più comunemente utilizzato è la password. La principale limitazione delle 
password è che al momento dell’uso esse vengono esposte all’osservazione, il ché le rende vulnerabili allo 
spionaggio. 

Dopo aver passato in rassegna la storia della crittografia, nel 1883 il linguista fiammingo Auguste Kerckhoffs 
pubblicò le proprie teorie in un articolo pionieristico sulla crittografia militare. Kerckhoffs sosteneva che 
anziché fare affidamento sulla segretezza (oscurità) del sistema, la sicurezza dovesse basarsi sulla 
protezione delle chiavi, poiché in caso di violazione sarebbe stato sufficiente sostituire solo queste ultime, 
non l’intero sistema. 
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Figura 2. Flusso dei dati nell’autenticazione sfida-risposta. 

Un efficace metodo di autenticazione simmetrica basato su chiavi funziona come illustrato in figura 1: la 
chiave segreta e i dati da autenticare ("messaggio") vengono utilizzati come input per calcolare un codice di 
autenticazione del messaggio (Message-Authentication-Code, MAC). Il MAC viene quindi unito al messaggio 
e trasmesso su richiesta. Il ricevente effettua lo stesso calcolo e confronta la propria versione del MAC con 
quella che ha ricevuto insieme al messaggio. Se i due MAC coincidono, il messaggio è autentico. Il punto 
debole di questo modello di base, tuttavia, è che un messaggio ed un MAC statici, intercettati da un 
aggressore, possono essere successivamente replicati da un mittente non autentico ed essere considerati 
autentici. 

Per provare l’autenticità dell’entità che ha dato origine al MAC (ad esempio l’accessorio di un sistema), il 
ricevente (cioè il sistema host a cui l’accessorio è connesso) genera un numero casuale e lo invia come 
sfida all’originatore. L’originatore del MAC deve quindi calcolare un nuovo MAC a partire da tre elementi (la 
chiave segreta, il messaggio, il numero di sfida) e rispedirlo al ricevente. Se l'originatore si dimostra capace 
di generare un MAC valido per ogni sfida, è certamente a conoscenza della chiave segreta e quindi può 
essere considerato autentico. La figura 2 illustra questo flusso di autenticazione sfida-risposta e gli elementi 
di dati ad esso associati. 

In crittografia, un algoritmo che genera un MAC di lunghezza fissa a partire da un messaggio è detto 
“funzione di hash unidirezionale”. Il termine “unidirezionale” indica che matematicamente non è fattibile 
ricavare dal MAC di lunghezza fissa il messaggio iniziale, generalmente più lungo, comprendente la chiave 
segreta. 

Due funzioni di hash unidirezionale che sono state oggetto di esame approfondito ed hanno ottenuto 
certificazioni internazionali sono gli algoritmi SHA-1 e SHA-2 sviluppati dal National Institute of Standards 
and Technology (NIST), descritti nel documento FIPS 180. Le elaborazioni matematiche su cui si basano 
queste funzioni sono disponibili pubblicamente nel sito web di NIST. Le caratteristiche distintive dei due 
algoritmi sono: 

1) irreversibilità - matematicamente non è fattibile determinare l’informazione d’ingresso corrispondente a un 
dato MAC; 

2) resistenza alle collisioni - è praticamente impossibile trovare più di un messaggio di ingresso che produca 
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il medesimo MAC; 

3) elevato effetto valanga - ogni minimo cambiamento dell’informazione in ingresso produce un 
cambiamento significativo del MAC risultante. Per queste ragioni, oltre che per la serietà degli esami a cui 
sono stati sottoposti internazionalmente, Maxim ha scelto gli algoritmi SHA-1 e SHA-2 per l'autenticazione 
sfida-risposta dei propri autenticatori sicuri. Nei propri prodotti più recenti, in particolare, l’azienda ha 
implementato una variante di SHA-2 denominata SHA-256. 



Figura 3. Esempio di applicazione base. 


Autenticazione sicura a basso costo: l’implementazione del sistema 

Grazie all'Interfaccia 1-Wire®, qualunque sistema dotato di capacità di elaborazione digitale - es. di un 
microcontrollore (pC) - può essere facilmente equipaggiato con un autenticatore sicuro, come il DeepCover® 
Secure Authenticator (DS28E15). Nel caso più semplice, è sufficiente disporre di un pin di porta libero nel 
microcontrollore ed aggiungere un resistore di pull-up per la linea 1-Wire, come illustrato in figura 3. Questo 
approccio può però essere potenzialmente rischioso se si impiega un microcontrollore non sicuro, che può 
essere studiato da un aggressore per comprendere e compromettere le funzioni di sicurezza. 

In alternativa, come illustrato in figura 4, il DS28E15 può essere azionato e controllato tramite un apposito 
IC, come il coprocessore SHA-256 DeepCover Secure Authenticator (DS2465) con interfaccia master 1-Wire 
integrata. Sebbene il DS28E15 possa essere gestito anche con un approccio basato sul solo 
microcontrollore, l’impiego del DS2465 offre vari vantaggi: 

1) solleva il pC host dal compito dei calcoli SHA-256; 

2) permette di conservare in modo molto sicuro la chiave segreta SHA-256 del sistema; 

3) solleva il pC host dal compito di generare la forma d’onda 1-Wire. 



Figura 4. Uso di un coprocessore per aumentare la sicurezza. 


Prevenzione delle contraffazioni 

I sistemi dotati di elementi sostituibili - come sensori, periferiche, moduli o materiali di consumo - sono 
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comunemente presi di mira da aziende ‘aftermarket’ non autorizzate. Le versioni contraffatte degli elementi 
sostituibili possono causare preoccupazioni per la sicurezza (safety) del sistema, ridurre la qualità 
dell’applicazione e, in generale, avere un impatto negativo sulla soluzione OEM. Aggiungere alla soluzione 
una funzione di autenticazione sicura consente al sistema host di testare l’autenticità del sensore o del 
modulo e, se viene rilevata una contraffazione, di compiere azioni appropriate alla specifica applicazione. 
Come illustrato in figura 5, per confermare l’autenticità viene svolta una sequenza sfida-risposta tra il sistema 
e la periferica ad esso collegata. 



Figura 5. Test di autenticità con una sequenza sfida-risposta. 


Gestione delle licenze HW/SW embedded 

I “progetti di riferimento”, che vengono concessi in licenza ed eventualmente si traducono in prodotti 
fabbricati da terze parti, richiedono barriere protettive per impedire l’uso non autorizzato della relativa 
proprietà intellettuale. Per il calcolo dei compensi occorre inoltre tenere traccia ed accertare il numero degli 
esemplari prodotti. Un autenticatore SHA-256 pre-programmato (con una chiave segreta, una memoria 
utente ed impostazioni installate prima della consegna al fabbricante di terza parte), come il DeepCover 
Secure Authenticator (DS28E25), può facilmente soddisfare questi ed altri requisiti. Il progetto di riferimento 
effettua un’autoverifica all’accensione (figura 6) eseguendo una sequenza di autenticazione con il DS28E25. 
Soltanto un DS28E25 con una chiave segreta valida, nota solo all’azienda licenziante ed all’elettronica del 
progetto di riferimento, è in grado di fornire in risposta un MAC valido. Se viene rilevato un MAC non valido, il 
processore del progetto di riferimento può compiere azioni appropriate alla specifica applicazione. Un 
vantaggio aggiuntivo di questo approccio è la possibilità di concedere in licenza ed abilitare selettivamente le 
varie funzioni del progetto di riferimento, tramite le impostazioni conservate nella memoria sicura del 
DS28E25 (per un approfondimento di questo concetto si veda il paragrafo “Gestione delle soft-feature”). 

Esistono due modalità sicure per fornire al licenziatario o al fabbricante di terza parte il DS28E25, od un altro 
autenticatore sicuro, dotato di una chiave segreta valida: 

1) il dispositivo può essere pre-programmato dall’azienda che concede in licenza il progetto di riferimento, 
oppure 

2) pre-programmato da Maxim secondo i criteri stabiliti dalla società licenziante e quindi fornito al fabbricante 
di terza parte. 

In entrambi i casi, il numero dei dispositivi inviati al licenziatario o al fabbricante è noto e può essere 
utilizzato per calcolare i compensi dovuti per la licenza. 
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Figura 6. Autenticazione del progetto di riferimento. 

Verifica dell’autenticità dell’hardware 

Per quanto riguarda la verifica dell’autenticità dell’hardware occorre considerare due casi (figura 7): 

1) una scheda PCB clonata contenente una copia esatta del firmware del uC o della configurazione 
dell’FPGA; 

2) un sistema host clonato. 

In questo esempio viene usato il DS28E01-100 basato su SHA-1. 

Nel primo caso, il firmware o l’FPGA controlla l’autenticità della scheda PCB clonata. Affinché la verifica 
abbia successo, il produttore del clone deve caricare una chiave segreta in un autenticatore sicuro per 
scrivere i dati nella EEPROM utente. In questo modo i dati possono apparire corretti, ma tuttavia la chiave 
segreta non è valida nell’ambito di quel sistema. A causa delle difficoltà legate alle modifiche ed alla 
necessità di mantenere la compatibilità con l’host, il firmware o la configurazione dell’FPGAdeve essere una 
copia esatta dell’originale. Se durante la fase di accensione la scheda esegue un’autenticazione sfida- 
risposta con il DS28E01-100, il MAC generato da questo dispositivo sarà diverso dal MAC calcolato dal 
firmware o dall’FPGA. Questa mancata corrispondenza dimostra chiaramente che la scheda non è autentica. 
Il sistema può rilevare ciò eseguendo una sequenza sfida-risposta nei confronti della scheda e può quindi 
compiere azioni appropriate alla specifica applicazione. 

Nel secondo caso, la scheda PCB controlla l’autenticità del sistema host. La verifica può utilizzare la 
seguente procedura: 

1) generare un numero di sfida e far calcolare al DS28E01-100 un MAC di autenticazione sfida-risposta; 

2) inviare gli stessi dati utilizzati per il calcolo del MAC (tranne la chiave segreta, ovviamente) ali’host della 
rete, che quindi calcola e restituisce un MAC di autenticazione sfida-risposta basato su quei dati e sulla 
propria chiave segreta. 

Se i due MAC coincidono, l’host può essere ritenuto autentico dalla scheda. 



Figura 7. Esempio di autenticazione dell’hardware. 

Gestione delle soft-feature 

In termini di dimensioni, i sistemi elettronici coprono una gamma che va dai prodotti portatili fino ad apparati 
che occupano diversi rack. Maggiori sono le dimensioni, maggiore è anche il relativo costo di sviluppo. Per 


Fare Elettronica n.347 - Settembre 2014 p.73 






































tenere i costi sotto controllo, si cerca quindi di costruire i grandi sistemi partendo da una selezione limitata di 
sottosistemi più piccoli (schede). Spesso non tutte le funzioni di un sottosistema sono necessarie per una 
specifica applicazione. Anziché eliminare le funzioni superflue, è più conveniente disabilitarle tramite il 
software di controllo, lasciando la scheda invariata. Questa scelta, tuttavia, crea un nuovo problema: un 
cliente scaltro che necessiti di diversi sistemi con funzionalità completa potrebbe comprare un unico 
esemplare con queste caratteristiche e quindi copiarne il software su numerosi esemplari con funzionalità 
ridotte, di prezzo inferiore. Questi ultimi assumerebbero così tutte le caratteristiche dell’esemplare più 
costoso ed il fornitore del sistema riceverebbe un compenso inferiore al dovuto. 

Installando su ogni scheda/sottosistema un dispositivo SHA-256 di Maxim, come il DeepCover Secure 
Authenticator (DS28E22), il fornitore del sistema può difendersi da questo tipo di frode. Oltre a servire per 
l’autenticazione sfida-risposta, lo stesso DS28E22 può conservare le impostazioni di configurazione 
individuali nella propria EEPROM utente. Come illustrato nel paragrafo “Sicurezza dei dati”, in questo modo 
le impostazioni sono protette dalle modifiche non autorizzate, ed il fornitore del sistema assume il pieno 
controllo di questo aspetto. Le impostazioni di configurazione possono essere conservate nella forma che il 
progettista del sistema ritiene più appropriata, ad esempio come bitmap o come parole di codice. 

Il dispositivo di autenticazione sicura 

Architettura complessiva 

L’engine SHA dei dispositivi SHA-1 e SHA-256 può essere azionato in tre modi diversi a seconda 
dell’operazione da eseguire. In tutti i casi, l’engine riceve i dati di ingresso e calcola un MAC come risultato. 
Per ciascun tipo di operazione ci sono specificità nei dati inviati all’engine SHA, legate all’uso previsto del 
MAC risultante. Il requisito fondamentale dei sistemi sicuri basati su chiave simmetrica è che, per ogni 
operazione SHA, l’host debba conoscere o essere in grado di calcolare la chiave segreta conservata nel 
dispositivo slave, al fine di essere autenticato. 

Nota: date le caratteristiche di sicurezza dei prodotti di autenticazione sicura, i dettagli dei dispositivi sono 
stati omessi da questo documento. Altre informazioni sono presenti nelle versioni complete dei fogli 
specifiche dei singoli dispositivi, disponibili previo accordo di non divulgazione (Non-Disclosure-Agreement, 
NDA). 



Figura 8. Flusso dei dati per il MAC di autenticazione sfida-risposta. 


MAC di autenticazione sfida-risposta 

La funzione principale degli autenticatori sicuri SHA-1 e SHA-256 è l’autenticazione sfida-risposta. L’host 
invia un numero casuale di sfida e incarica il dispositivo slave di calcolare un MAC di risposta, a partire dai 
diversi elementi che insieme costituiscono il “messaggio” (figura 8): il numero di sfida, la chiave segreta, la 
memoria utente e dati aggiuntivi. 

Al termine del calcolo, il dispositivo slave invia il proprio MAC all’host per la verifica. L’host quindi ripete il 
calcolo del MAC usando una chiave segreta valida e gli stessi dati di messaggio che sono stati usati dallo 
slave. La coincidenza con il MAC ricevuto dallo slave dimostra l’autenticità del dispositivo, poiché solo uno 
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slave autentico può rispondere correttamente alla sequenza sfida-risposta. È cruciale che la sfida sia basata 
su dati casuali. Un numero di sfida che non cambia mai apre la strada ad attacchi ripetitivi (replay) che 
usano un MAC statico, valido, registrato e replicato, anziché un MAC calcolato all’istante da uno slave 
autentico. 

Sicurezza dei dati 

Oltre a provare l’autenticità, è estremamente desiderabile garantire che i dati conservati nel dispositivo slave 
siano affidabili. Per questa ragione, l’accesso di scrittura alla EEPROM dell’autenticatore sicuro è soggetto a 
restrizioni. Prima di copiare i dati dal buffer di ingresso alla EEPROM o ai registri di controllo, il dispositivo 
slave esige che l’host richiedente dia prova della propria autenticità fornendo un valido MAC di 
autenticazione per accesso di scrittura. Il dispositivo slave calcola questo MAC a partire dai nuovi dati nella 
propria memoria buffer di ingresso, dalla propria chiave segreta e da dati aggiuntivi, come illustrato in figura 
9. 



Figura 9. Flusso dei dati per un MAC di autenticazione per accesso di scrittura. 

Un host autentico conosce, o è in grado di calcolare, la chiave segreta e può generare un MAC valido per 
l’accesso di scrittura. Quando riceve il MAC dall’host durante il comando di copia, lo slave lo confronta con il 
proprio risultato. I dati vengono trasferiti dal buffer di ingresso alla loro destinazione nella EEPROM solo se i 
due MAC coincidono. Ovviamente le pagine di memoria a scrittura protetta non possono essere modificate, 
nemmeno se il MAC è corretto. 


Protezione della chiave segreta 

L’architettura degli autenticatori sicuri di Maxim consente di caricare direttamente la chiave segreta nel 
dispositivo. La chiave segreta è protetta contro la lettura e, se richiesto, anche contro la scrittura; in 
quest’ultimo caso la chiave non può mai essere cambiata. Questo meccanismo di protezione è efficace a 
patto che durante l’installazione iniziale, nel sito produttivo dell’apparato, l’accesso alla chiave segreta sia 
sicuro e controllato. 

La protezione della chiave segreta può essere aumentata in vari modi: 

1) assegnando al dispositivo slave il compito di calcolare la propria chiave segreta; 

2) suddividendo questo calcolo in più fasi effettuate in siti diversi; 

3) creando chiavi segrete esclusive legate al singolo dispositivo, includendo nel calcolo il numero che 
identifica univocamente ogni esemplare; 

4) una combinazione delle modalità 2 e 3. 
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Se ogni autenticatone sicuro calcola la propria chiave segreta, i relativi “ingredienti” sono resi noti ma la 
chiave vera e propria non viene mai esposta. Se la chiave segreta viene calcolata in più fasi presso siti 
diversi, in ciascun sito vengono resi noti solo gli ingredienti usati localmente, il che fornisce un metodo per 
controllare la divulgazione della chiave segreta finale. Se si creano chiavi segrete esclusive legate a ogni 
singolo esemplare del dispositivo, l’host deve compiere un calcolo aggiuntivo ma diviene possibile 
minimizzare il danno potenziale in caso di rivelazione accidentale della chiave segreta. Il più alto livello 
possibile di segretezza si ottiene se la chiave segreta è calcolata in più fasi e legata al singolo esemplare di 
dispositivo. Il setup degli host, così come degli slave, deve però essere effettuato in siti diversi per evitare di 
compromettere la segretezza del sistema. 



Figura 10. Flusso dei dati per il calcolo di una nuova chiave segreta. 

Se incaricato di calcolare una chiave segreta, l’autenticatore sicuro usa il proprio engine SHA-1 o SHA-2 e 
calcola un MAC usando elementi di dati specifici di quel particolare dispositivo, come illustrato in figura 10. Il 
MAC risultante viene quindi utilizzato per generare la nuova chiave segreta. 

Per Approfondire: http://www.maximinteqrated.com/en/products/diqital/embedded-security.html 
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